Mybatis-Plus 3.0代码生成器

Posted Kmily_Lee

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis-Plus 3.0代码生成器相关的知识,希望对你有一定的参考价值。

  1 package com.kyplatform.generator;
  2 
  3 import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
  4 import com.baomidou.mybatisplus.core.toolkit.StringUtils;
  5 import com.baomidou.mybatisplus.generator.AutoGenerator;
  6 import com.baomidou.mybatisplus.generator.config.*;
  7 import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
  8 
  9 import java.util.Scanner;
 10 
 11 /**
 12  * mybatis代码生成器
 13  */
 14 public class CodeGenerator {
 15     /**
 16      * <p>
 17      * 读取控制台内容
 18      * </p>
 19      */
 20     public static String scanner(String tip) {
 21         Scanner scanner = new Scanner(System.in);
 22         StringBuilder help = new StringBuilder();
 23         help.append("请输入" + tip + ":");
 24         System.out.println(help.toString());
 25         if (scanner.hasNext()) {
 26             String ipt = scanner.next();
 27             if (StringUtils.isNotEmpty(ipt)) {
 28                 return ipt;
 29             }
 30         }
 31         throw new MybatisPlusException("请输入正确的" + tip + "!");
 32     }
 33 
 34     public static void main(String[] args) {
 35         // 代码生成器
 36         AutoGenerator mpg = new AutoGenerator();
 37 
 38         // 全局配置
 39         GlobalConfig gc = new GlobalConfig();
 40         String projectPath = System.getProperty("user.dir");
 41         gc.setOutputDir(projectPath + "/src/main/java");//生成文件的输出目录
 42         gc.setAuthor("zhicaili");//开发人员
 43         gc.setOpen(true);//是否打开输出目录
 44         gc.setServiceName("%sService");//service 命名方式
 45         gc.setServiceImplName("%sServiceImpl");//service impl 命名方式
 46         // 自定义文件命名,注意 %s 会自动填充表实体属性!
 47         gc.setMapperName("%sMapper");
 48         gc.setXmlName("%sMapper");
 49         gc.setFileOverride(true);
 50         gc.setActiveRecord(true);
 51         gc.setEnableCache(false);// XML 二级缓存
 52         gc.setBaseResultMap(true);// XML ResultMap
 53         gc.setBaseColumnList(false);// XML columList
 54         mpg.setGlobalConfig(gc);
 55 
 56         // 数据源配置
 57         DataSourceConfig dsc = new DataSourceConfig();
 58         dsc.setUrl("jdbc:mysql://127.0.0.1:3306/xxxxx?useUnicode=true&useSSL=false&characterEncoding=utf8");
 59         // dsc.setSchemaName("public"); 数据库 schema name
 60         dsc.setDriverName("com.mysql.jdbc.Driver");
 61         dsc.setUsername("root");
 62         dsc.setPassword("******");
 63         mpg.setDataSource(dsc);
 64 
 65         // 包配置
 66         PackageConfig pc = new PackageConfig();
 67         //pc.setModuleName(scanner("模块名"));//父包模块名
 68         pc.setParent("com.kyplatform.admin");//父包名。// 自定义包路径  如果为空,将下面子包名必须写全部, 否则就只需写子包名
 69         pc.setEntity("pojo");
 70         pc.setService("service");
 71         pc.setServiceImpl("service.impl");
 72         pc.setController("controller");//设置控制器包名
 73         mpg.setPackageInfo(pc);
 74 
 75         // 自定义配置
 76 /*        InjectionConfig cfg = new InjectionConfig() {
 77             @Override
 78             public void initMap() {
 79                 // to do nothing
 80             }
 81         };
 82         List<FileOutConfig> focList = new ArrayList<>();
 83         focList.add(new FileOutConfig("/templates/mapper.xml.ftl") {
 84             @Override
 85             public String outputFile(TableInfo tableInfo) {
 86                 // 自定义输入文件名称
 87                 return projectPath + "/src/main/resources/mapper/" + pc.getModuleName()
 88                         + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;
 89             }
 90         });*/
 91  /*       cfg.setFileOutConfigList(focList);
 92         mpg.setCfg(cfg);*/
 93         mpg.setTemplate(new TemplateConfig().setXml(null));
 94 
 95         // 策略配置
 96         StrategyConfig strategy = new StrategyConfig();
 97         strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略
 98         strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略, 未指定按照 naming 执行
 99       //  strategy.setSuperEntityClass("com.baomidou.ant.common.BaseEntity");//自定义继承的Entity类全称,带包名
100         strategy.setEntityLombokModel(true);//【实体】是否为lombok模型(默认 false)
101         strategy.setRestControllerStyle(true);//生成 @RestController 控制器
102         //strategy.setSuperControllerClass("com.baomidou.ant.common.BaseController");//自定义继承的Controller类全称,带包名
103         strategy.setInclude("tb_user","tb_organization","tb_person","tb_signin","tb_sys_config","tb_sys_log");//需要包含的表名,允许正则表达式
104         //strategy.setSuperEntityColumns("id");//自定义基础的Entity类,公共字段
105         strategy.setControllerMappingHyphenStyle(true);//驼峰转连字符
106         strategy.setTablePrefix("tb_");//表前缀
107         mpg.setStrategy(strategy);
108         //mpg.setTemplateEngine(new FreemarkerTemplateEngine());
109         mpg.execute();
110     }
111 
112 
113 }

 

以上是关于Mybatis-Plus 3.0代码生成器的主要内容,如果未能解决你的问题,请参考以下文章

mybatis-plus代码生成器代码

mybatis-plus代码生成器完整示例代码

MyBatis-plus 代码自动生成器

详解:MyBatis-Plus 代码生成器的使用

详解:MyBatis-Plus 代码生成器的使用

详解:MyBatis-Plus 代码生成器的使用