mybatis_plus之代码生成器的应用

Mybatis-Plus代码生成器

代码生成器介绍

代码生成器顾名思义就是为我们生成一些代码,省去了我们一些时间。

AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码。

极大的提升了开发效率,MyBatis-Plus从3.0.3 之后移除了代码生成器与模板引擎的默认依赖,需要手动添加相关依赖,才能实现代码生成器功能。

操作流程

1、构建maven工程引入相关依赖

<!-- 数据库mysql驱动 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.47</version>
</dependency>

<!-- mybatis-plus 的场景启动器-->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.0</version>
</dependency>
<!-- mybatis-plus 代码生成器包-->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>3.4.1</version>
</dependency>
<!-- 代码生成器需要的模板依赖-->
<dependency>
    <groupId>org.apache.velocity</groupId>
    <artifactId>velocity-engine-core</artifactId>
    <version>2.3</version>
</dependency>

2、GlobalConfig全局配置编码

@SpringBootTest
class SpringbootMybatisPlusGeneratorApplicationTests {
    
    

    @Test
    void contextLoads() {
    
    

        // 代码生成器
        AutoGenerator mpg = new AutoGenerator();

// ======  全局配置  ======
        GlobalConfig gc = new GlobalConfig();
        // 工程所在路径
        String projectPath = System.getProperty("user.dir");
        // 指定代码在指定的目录中生成
        gc.setOutputDir(projectPath + "/src/main/java");
        // 作者名称
        gc.setAuthor("chenshuang");
        // 设置生成的日期只为date格式
        gc.setDateType(DateType.ONLY_DATE);
        // 默认工具栏文件夹是否打开
        gc.setOpen(false);
        // gc.setSwagger2(true); 实体属性 Swagger2 注解
        mpg.setGlobalConfig(gc);

// ======  数据源配置 ======
        DataSourceConfig dsc = new DataSourceConfig();
        dsc.setUrl("jdbc:mysql:///mybatisplus?useUnicode=true&useSSL=false&characterEncoding=utf8");
        // dsc.setSchemaName("public");
        dsc.setDriverName("com.mysql.jdbc.Driver");
        dsc.setUsername("root");
        dsc.setPassword("123456");
        mpg.setDataSource(dsc);

// ======  包的配置 ======
        PackageConfig pc = new PackageConfig();
        pc.setParent("com.chenshuang");
        pc.setEntity("entity");
        pc.setMapper("mapper");
        pc.setController("controller");
        pc.setServiceImpl("service.xml");
        mpg.setPackageInfo(pc);

// ======  模板的配置 ======
        TemplateConfig templateConfig = new TemplateConfig();
        // 默认关闭不需要的生成内容
//        templateConfig.setXml(null);
        templateConfig.setService(null);
        templateConfig.setServiceImpl(null);
        mpg.setTemplate(templateConfig);

// ======  策略配置 ======
        StrategyConfig strategy = new StrategyConfig();
        // 数据库表映射到实体的命名策略  【表名】
        strategy.setNaming(NamingStrategy.underline_to_camel);
        // 数据库表字段映射到实体的命名策略 【列名】【e_id---eId】
        strategy.setColumnNaming(NamingStrategy.underline_to_camel);
        strategy.setSuperEntityClass("com.baomidou.mybatisplus.extension.activerecord.Model");
        strategy.setEntityLombokModel(true);
        strategy.setRestControllerStyle(true);
        // 写数据库中要映射的表名 用逗号分隔
        String tableNames="user";
        strategy.setInclude(tableNames.split(","));
        strategy.setControllerMappingHyphenStyle(true);
        mpg.setStrategy(strategy);

// ======  执行代码生成器 ======
        mpg.execute();
    }
}

3、配置

3、执行生成器代码完成测试

在主启动类上用@MapperScan扫描mapper接口
@MapperScan("com.offcn.ssm.mapper")

在application.yml中添加数据库配置信息
 spring:
datasource:
 driver-class-name: com.mysql.jdbc.Driver
 url: jdbc:mysql:///mybatis_plus
 username: root
 password: root
logging:
level:
 com:
   offcn:
     mybatis:
       dao: debug

在生成的contorller中编写查询方法
@RestController
@RequestMapping("/tb-employee")
public class TbEmployeeController {
     
     

 @Autowired
 private TbEmployeeService tbEmployeeService;
 @RequestMapping("/emps")
 public List<TbEmployee> getEmployees(){
     
     
     List<TbEmployee> list = tbEmployeeService.list();
     return list;
 }

}

访问:http://localhost:8080/user/getuser

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/PIKapikaaaa/article/details/125628122