AutoCode.java 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. package com.template;
  2. import com.baomidou.mybatisplus.annotation.DbType;
  3. import com.baomidou.mybatisplus.annotation.FieldFill;
  4. import com.baomidou.mybatisplus.annotation.IdType;
  5. import com.baomidou.mybatisplus.generator.AutoGenerator;
  6. import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
  7. import com.baomidou.mybatisplus.generator.config.GlobalConfig;
  8. import com.baomidou.mybatisplus.generator.config.PackageConfig;
  9. import com.baomidou.mybatisplus.generator.config.StrategyConfig;
  10. import com.baomidou.mybatisplus.generator.config.po.TableFill;
  11. import com.baomidou.mybatisplus.generator.config.rules.DateType;
  12. import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
  13. import java.util.ArrayList;
  14. /**
  15. * @Author: binguo
  16. * @Date: 2023/3/30 星期四 15:46
  17. * @Description: com.video
  18. * @Version: 1.0
  19. */
  20. public class AutoCode {
  21. public static void main(String[] args) {
  22. // 需要构建一个 代码自动生成器 对象
  23. AutoGenerator mpg = new AutoGenerator();
  24. // 配置策略
  25. // 1、全局配置
  26. GlobalConfig gc = new GlobalConfig();
  27. String projectPath = System.getProperty("user.dir");
  28. gc.setOutputDir(projectPath + "/src/main/java");
  29. gc.setAuthor("ceshi");
  30. gc.setOpen(false);
  31. gc.setFileOverride(false); // 是否覆盖
  32. gc.setServiceName("%sService"); // 去Service的I前缀
  33. gc.setIdType(IdType.UUID);
  34. gc.setDateType(DateType.ONLY_DATE);
  35. gc.setSwagger2(true);
  36. mpg.setGlobalConfig(gc);
  37. //2、设置数据源
  38. DataSourceConfig dsc = new DataSourceConfig();
  39. dsc.setUrl("jdbc:mysql://192.168.161.220:3306/repair_report?useUnicode=tru&characterEncoding=UTF-8&useSSL=false&useAffectedRows=true&allowPublicKeyRetrieval=true&allowMultiQueries=true&rewriteBatchedStatements=true&serverTimezone=Asia/Shanghai");
  40. dsc.setDriverName("com.mysql.cj.jdbc.Driver");
  41. dsc.setUsername("root");
  42. dsc.setPassword("root");
  43. dsc.setDbType(DbType.MYSQL);
  44. mpg.setDataSource(dsc);
  45. //3、包的配置
  46. PackageConfig pc = new PackageConfig();
  47. pc.setModuleName("auto");
  48. pc.setParent("com.template");
  49. pc.setEntity("model");
  50. pc.setMapper("mapper");
  51. pc.setService("services");
  52. pc.setController("controller");
  53. mpg.setPackageInfo(pc);
  54. //4、策略配置
  55. StrategyConfig strategy = new StrategyConfig();
  56. strategy.setInclude("repair_admin"); // 设置要映射的表名
  57. strategy.setNaming(NamingStrategy.underline_to_camel);//下划线转驼峰
  58. strategy.setColumnNaming(NamingStrategy.underline_to_camel);//下划线转驼峰
  59. strategy.setEntityLombokModel(true); // 自动lombok;
  60. strategy.setLogicDeleteFieldName("deleted");//逻辑删除 调用service的删除方法不会真删除 会把deleted字段的值改为1 (未删除="0",删除="1")
  61. // 自动填充配置
  62. TableFill deletedCreate = new TableFill("deleted", FieldFill.INSERT);
  63. TableFill timeCreate = new TableFill("create_time", FieldFill.INSERT);
  64. TableFill userCreate = new TableFill("create_user", FieldFill.INSERT);
  65. TableFill timeModified = new TableFill("update_time", FieldFill.INSERT_UPDATE);
  66. TableFill userModified = new TableFill("update_user", FieldFill.INSERT_UPDATE);
  67. ArrayList<TableFill> tableFills = new ArrayList<>();
  68. tableFills.add(deletedCreate);
  69. tableFills.add(timeCreate);
  70. tableFills.add(userCreate);
  71. tableFills.add(timeModified);
  72. tableFills.add(userModified);
  73. strategy.setTableFillList(tableFills);
  74. // 乐观锁
  75. strategy.setVersionFieldName("version");
  76. strategy.setRestControllerStyle(true);
  77. strategy.setControllerMappingHyphenStyle(true); //localhost:8080/hello_id_2
  78. mpg.setStrategy(strategy);
  79. mpg.execute(); //执行
  80. }
  81. }