AutoGenerate.java 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. package com.fdkankan.fusion.generate;
  2. import com.baomidou.mybatisplus.core.mapper.BaseMapper;
  3. import com.baomidou.mybatisplus.generator.FastAutoGenerator;
  4. import com.baomidou.mybatisplus.generator.config.OutputFile;
  5. import com.baomidou.mybatisplus.generator.config.rules.DateType;
  6. import java.util.ArrayList;
  7. import java.util.Arrays;
  8. import java.util.Collections;
  9. import java.util.List;
  10. public class AutoGenerate {
  11. public static void main(String[] args) {
  12. String path =System.getProperty("user.dir") ;
  13. generate(path,"fusion", getTables(new String[]{
  14. "t_case_inquest_file"
  15. }));
  16. // generate(path,"goods", getTables(new String[]{
  17. // "t_camera","t_camera_detail","t_camera_out","t_camera_space","t_camera_version",
  18. // "t_company","t_goods","t_goods_sku","t_cart","t_goods_spec",
  19. // "t_goods_spec_value","t_goods_spu_spec","t_sn_code"
  20. // }));
  21. //
  22. // generate(path,"order", getTables(new String[]{
  23. // "t_increment_order","t_invoice","t_order","t_order_item",
  24. // "t_pre_sale","t_space_sdk","t_trade_log","t_commerce_order","t_download_order","t_expansion_order"
  25. // }));
  26. // generate(path,"order", getTables(new String[]{
  27. // "t_virtual_order"
  28. // }));
  29. //
  30. // generate(path,"user", getTables(new String[]{
  31. // "t_user","t_user_increment","t_manager","t_province","t_increment_type","t_intercom_message","t_receiver_info"
  32. // }));
  33. }
  34. public static List<String> getTables(String [] tableNames){
  35. return new ArrayList<>(Arrays.asList(tableNames));
  36. }
  37. public static void generate(String path,String moduleName, List<String> tables){
  38. // FastAutoGenerator.create("jdbc:mysql://192.168.0.25:3306/fd_fusion_xj",
  39. // "root","mysql123!ROOT.")
  40. FastAutoGenerator.create("jdbc:mysql://192.168.0.25:3306/fd_fusion",
  41. "root","4dkk2023cuikuan%")
  42. .globalConfig(builder -> {
  43. builder.author("") //作者
  44. .outputDir(path+"\\src\\main\\java") //输出路径(写到java目录)
  45. //.enableSwagger() //开启swagger
  46. .commentDate("yyyy-MM-dd")
  47. .dateType(DateType.ONLY_DATE)
  48. .fileOverride(); //开启覆盖之前生成的文件
  49. })
  50. .packageConfig(builder -> {
  51. builder.parent("com.fdkankan")
  52. .moduleName(moduleName)
  53. .entity("entity")
  54. .service("service")
  55. .serviceImpl("service.impl")
  56. .controller("controller")
  57. .mapper("mapper")
  58. .xml("test.mapper")
  59. .pathInfo(Collections.singletonMap(OutputFile.mapperXml,path+"\\src\\main\\resources\\mapper\\"+moduleName));
  60. })
  61. .strategyConfig(builder -> {
  62. builder.addInclude(tables)
  63. .addTablePrefix("t_")
  64. .serviceBuilder()
  65. .formatServiceFileName("I%sService")
  66. .formatServiceImplFileName("%sServiceImpl")
  67. .entityBuilder()
  68. .enableLombok()
  69. .logicDeleteColumnName("tb_status")
  70. .enableTableFieldAnnotation()
  71. //.superClass(BaseEntity.class)
  72. .controllerBuilder()
  73. .formatFileName("%sController")
  74. .enableRestStyle()
  75. .mapperBuilder()
  76. .superClass(BaseMapper.class)
  77. .formatMapperFileName("I%sMapper")
  78. .enableMapperAnnotation()
  79. .formatXmlFileName("%sMapper");
  80. })
  81. // .templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
  82. .execute();
  83. }
  84. }