MyBatis-Plus代码生成器

矫情吗;* 2022-09-14 02:59 191阅读 0赞

前言:本文主要讲解如何使用MyBatis-Plus的代码生成器,能根据数据库表自动生成相对于的实体类、映射层、服务层、控制器层,使用代码生成器能大大提高工作效率,减少重复工作量。本文与SpringBoot配合使用。

简介

官网:MyBatis-Plus代码生成器文档

AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码,极大的提升了开发效率。

添加依赖

  1. <properties>
  2. <mybatis-plus.version>3.4.3</mybatis-plus.version>
  3. <mybatis-plus.generator.vision>3.4.1</mybatis-plus.generator.vision>
  4. <velocity.version>2.3</velocity.version>
  5. </properties>
  6. <!--Mybatis-Plus-->
  7. <dependency>
  8. <groupId>com.baomidou</groupId>
  9. <artifactId>mybatis-plus-boot-starter</artifactId>
  10. <version>${mybatis-plus.version}</version>
  11. </dependency>
  12. <!--Mybatis-Plus代码生成器-->
  13. <dependency>
  14. <groupId>com.baomidou</groupId>
  15. <artifactId>mybatis-plus-generator</artifactId>
  16. <version>${mybatis-plus.generator.vision}</version>
  17. </dependency>
  18. <!--velocity 模板引擎 MP代码生成器需要-->
  19. <dependency>
  20. <groupId>org.apache.velocity</groupId>
  21. <artifactId>velocity-engine-core</artifactId>
  22. <version>${velocity.version}</version>
  23. </dependency>

配置文件

application.yml

  1. spring:
  2. datasource:
  3. url: jdbc:mysql://localhost:3306/数据库?useUnicode=true&useSSL=false&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
  4. driver-class-name: com.mysql.jdbc.Driver
  5. username: root
  6. password: 密码

代码

以下代码仅仅需要做简单修改即可使用。

CodeGenerator.java

  1. public class CodeGenerator {
  2. public void genCode() {
  3. // 1.创建代码生成器
  4. AutoGenerator mpg = new AutoGenerator();
  5. // 2.全局配置
  6. GlobalConfig gc = new GlobalConfig();
  7. String projectPath = System.getProperty("user.dir"); // 获取当前项目路径
  8. gc.setOutputDir(projectPath + "/src/main/java"); // 生成文件输出位置
  9. gc.setAuthor("jobob"); // 设置作者名称
  10. gc.setOpen(false); // 生成后是否自动打开资源管理器
  11. gc.setServiceName("%sService");// 去掉Service接口首字母I,默认IxxxService
  12. gc.setIdType(IdType.AUTO); // 主键策略
  13. // gc.setSwagger2(true); // 实体属性 Swagger2 注解
  14. mpg.setGlobalConfig(gc);
  15. // 3.数据源配置
  16. DataSourceConfig dsc = new DataSourceConfig();
  17. dsc.setUrl("jdbc:mysql://localhost:3306/数据库名?useUnicode=true&useSSL=false&characterEncoding=utf-8&serverTimezone=Asia/Shanghai");
  18. dsc.setDriverName("com.mysql.jdbc.Driver");
  19. dsc.setUsername("root");
  20. dsc.setPassword("密码");
  21. dsc.setDbType(DbType.MYSQL); // 设置数据库类型
  22. mpg.setDataSource(dsc);
  23. // 4.包配置
  24. PackageConfig pc = new PackageConfig();
  25. pc.setParent("com.baomidou.ant"); // 设置父包名
  26. pc.setEntity("pojo.entity"); // 实体类包名,与数据库表结构一一对应
  27. pc.setMapper("mapper"); // mapper包名
  28. pc.setXml("mapper.xml"); // mapper xml包名
  29. pc.setService("service"); // Service包名
  30. pc.setServiceImpl("service.impl"); // Service Impl包名
  31. pc.setController("controller"); // Controller包名
  32. mpg.setPackageInfo(pc);
  33. // 5.策略配置
  34. StrategyConfig strategy = new StrategyConfig();
  35. strategy.setInclude("user"); // 需要生成的表名
  36. strategy.setNaming(NamingStrategy.underline_to_camel);// 设置类名,下划线变驼峰
  37. strategy.setColumnNaming(NamingStrategy.underline_to_camel); // 设置列名,下划线变驼峰
  38. strategy.setEntityLombokModel(true); // lombok
  39. strategy.setLogicDeleteFieldName("is_deleted"); // 设置逻辑删除字段名并加上逻辑删除注解
  40. strategy.setEntityBooleanColumnRemoveIsPrefix(true); // 去掉Boolean类型字段的is_前缀
  41. strategy.setRestControllerStyle(true); // 生成 restful api风格控制器 @RestController
  42. // strategy.setTablePrefix("m_"); // 表前缀
  43. // strategy.setControllerMappingHyphenStyle(true);//mapping中驼峰转连字符
  44. mpg.setStrategy(strategy);
  45. // 6.执行
  46. mpg.execute();
  47. }
  48. }

参考资料来源:

【狂神说Java】MyBatisPlus最新完整教程通俗易懂

发表评论

表情:
评论列表 (有 0 条评论,191人围观)

还没有评论,来说两句吧...

相关阅读