No Description

CodeGenerator.java 7.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. package com.yt.zhylplat;
  2. import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
  3. import com.baomidou.mybatisplus.core.toolkit.StringPool;
  4. import com.baomidou.mybatisplus.core.toolkit.StringUtils;
  5. import com.baomidou.mybatisplus.generator.AutoGenerator;
  6. import com.baomidou.mybatisplus.generator.InjectionConfig;
  7. import com.baomidou.mybatisplus.generator.config.*;
  8. import com.baomidou.mybatisplus.generator.config.builder.ConfigBuilder;
  9. import com.baomidou.mybatisplus.generator.config.converts.MySqlTypeConvert;
  10. import com.baomidou.mybatisplus.generator.config.converts.OracleTypeConvert;
  11. import com.baomidou.mybatisplus.generator.config.po.TableInfo;
  12. import com.baomidou.mybatisplus.generator.config.rules.DbColumnType;
  13. import com.baomidou.mybatisplus.generator.config.rules.FileType;
  14. import com.baomidou.mybatisplus.generator.config.rules.IColumnType;
  15. import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
  16. import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
  17. import java.util.ArrayList;
  18. import java.util.List;
  19. import java.util.Scanner;
  20. /**
  21. * <p>
  22. * 读取控制台内容
  23. * </p>
  24. */
  25. public class CodeGenerator {
  26. /**
  27. * <p>
  28. * 读取控制台内容
  29. * </p>
  30. */
  31. public static String scanner(String tip) {
  32. Scanner scanner = new Scanner(System.in);
  33. StringBuilder help = new StringBuilder();
  34. help.append("请输入表名:");
  35. System.out.println(help.toString());
  36. if (scanner.hasNext()) {
  37. String ipt = scanner.next();
  38. if (StringUtils.isNotEmpty(ipt)) {
  39. return ipt;
  40. }
  41. }
  42. throw new MybatisPlusException("请输入正确的" + tip + "!");
  43. }
  44. public static void main(String[] args) {
  45. // 代码生成器
  46. AutoGenerator mpg = new AutoGenerator();
  47. // 全局配置
  48. GlobalConfig gc = new GlobalConfig();
  49. String projectPath = System.getProperty("user.dir");
  50. gc.setOutputDir(projectPath + "/src/main/java");
  51. gc.setAuthor("YTKJ");
  52. gc.setFileOverride(true);//是否覆盖原本存在的文件
  53. // gc.setAuthor("wuxiongwei");
  54. gc.setOpen(false);
  55. gc.setSwagger2(true); //实体属性增加 Swagger2 注解
  56. gc.setServiceName("%sService");//更改service 生成名称
  57. mpg.setGlobalConfig(gc);
  58. // 数据源配置
  59. DataSourceConfig dsc = new DataSourceConfig();
  60. dsc.setUrl("jdbc:mysql://192.168.1.200:3306/zhyl_db_jz?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&useSSL=false&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true&nullCatalogMeansCurrent=true");
  61. // dsc.setSchemaName("public");
  62. dsc.setDriverName("com.mysql.cj.jdbc.Driver");
  63. dsc.setUsername("root");
  64. dsc.setPassword("800100");
  65. dsc.setTypeConvert(new MySqlTypeConvert(){//数据库字段类型转换
  66. @Override
  67. public IColumnType processTypeConvert(GlobalConfig globalConfig, String fieldType) {
  68. if ( fieldType.toLowerCase().contains( "number" ) ) {
  69. return DbColumnType.INTEGER;
  70. }
  71. if ( fieldType.toLowerCase().contains( "datetime" ) ) {
  72. return DbColumnType.DATE;
  73. }
  74. if ( fieldType.toLowerCase().contains( "date" ) ) {
  75. return DbColumnType.DATE;
  76. }
  77. return (DbColumnType) super.processTypeConvert(globalConfig, fieldType);
  78. }
  79. });
  80. mpg.setDataSource(dsc);
  81. // 包配置
  82. PackageConfig pc = new PackageConfig();
  83. // pc.setModuleName(scanner("模块名"));
  84. pc.setParent("com.yt.zhylplat");
  85. pc.setMapper("dao"); //设置默认的mapper为dao
  86. // pc.setService("app.service");
  87. // pc.setServiceImpl("app.service.impl");
  88. //pc.setEntity("moduleZhjc.entity");
  89. // pc.setController("app.controller");
  90. // pc.setModuleName("moduleDabj");
  91. mpg.setPackageInfo(pc);
  92. // 自定义配置
  93. InjectionConfig cfg = new InjectionConfig() {
  94. @Override
  95. public void initMap() {
  96. // to do nothing
  97. }
  98. };
  99. // 如果模板引擎是 freemarker
  100. String templatePath = "/templates/mapper.xml.ftl";
  101. // 如果模板引擎是 velocity
  102. // String templatePath = "/templates/mapper.xml.vm";
  103. // 自定义输出配置
  104. List<FileOutConfig> focList = new ArrayList<>();
  105. // 自定义配置会被优先输出
  106. focList.add(new FileOutConfig(templatePath) {
  107. @Override
  108. public String outputFile(TableInfo tableInfo) {
  109. // 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!!
  110. return projectPath + "/src/main/resources/mapper/null" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;
  111. }
  112. });
  113. /*
  114. cfg.setFileCreate(new IFileCreate() {
  115. @Override
  116. public boolean isCreate(ConfigBuilder configBuilder, FileType fileType, String filePath) {
  117. // 判断自定义文件夹是否需要创建
  118. checkDir("调用默认方法创建的目录");
  119. return false;
  120. }
  121. });
  122. */
  123. cfg.setFileOutConfigList(focList);
  124. mpg.setCfg(cfg);
  125. // 配置模板
  126. TemplateConfig templateConfig = new TemplateConfig();
  127. // 配置自定义输出模板
  128. //指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别
  129. // templateConfig.setEntity("templates/entity2.java");
  130. // templateConfig.setService();
  131. // templateConfig.setController();
  132. templateConfig.setXml(null);
  133. //如果不生成对应的后台(service、serviceImpl、controller、mapper)代码,将下面注释打开即可
  134. // templateConfig.setServiceImpl(null);
  135. // templateConfig.setService(null);
  136. // templateConfig.setController(null);
  137. // templateConfig.setMapper(null);
  138. mpg.setTemplate(templateConfig);
  139. // 策略配置
  140. StrategyConfig strategy = new StrategyConfig();
  141. strategy.setNaming(NamingStrategy.underline_to_camel);
  142. strategy.setColumnNaming(NamingStrategy.underline_to_camel);
  143. //strategy.setSuperEntityClass("com.baomidou.ant.common.BaseEntity");
  144. strategy.setEntityLombokModel(true);
  145. strategy.setRestControllerStyle(true);
  146. //strategy.setSuperControllerClass("com.baomidou.ant.common.BaseController");
  147. strategy.setInclude(scanner("T_Citizen_Suggestion").split(","));
  148. strategy.setSuperEntityColumns("id");
  149. strategy.setEntityTableFieldAnnotationEnable(true);//实体类字段加对应数据库字段注解
  150. strategy.setControllerMappingHyphenStyle(true);
  151. strategy.setTablePrefix(pc.getModuleName() + "_");
  152. mpg.setStrategy(strategy);
  153. mpg.setTemplateEngine(new FreemarkerTemplateEngine());
  154. mpg.execute();
  155. }
  156. }