人间蒸发
2019-07-03 11:00:26
mybaties-plus自动代码生成,改成自己文件即可!
package com.slhc.basics.common; import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException; import com.baomidou.mybatisplus.core.toolkit.StringPool; import com.baomidou.mybatisplus.generator.AutoGenerator; import com.baomidou.mybatisplus.generator.InjectionConfig; import com.baomidou.mybatisplus.generator.config.*; import com.baomidou.mybatisplus.generator.config.po.TableInfo; import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy; import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine; import org.apache.commons.lang3.StringUtils; import java.util.ArrayList; import java.util.List; import java.util.Scanner; /** * * @ClassName: CodeGeneration * @Description: 代码生成器 * @author aqian666 * @date 2019年7月2日14:08:37 */ public class CodeGenerator { /** * <p> * 读取控制台内容 * </p> */ public static String scanner(String tip) { Scanner scanner = new Scanner(System.in); StringBuilder help = new StringBuilder(); help.append("请输入" + tip + ":"); System.out.println(help.toString()); if (scanner.hasNext()) { String ipt = scanner.next(); if (StringUtils.isNotEmpty(ipt)) { return ipt; } } throw new MybatisPlusException("请输入正确的" + tip + "!"); } public static void main(String[] args) { // 代码生成器 AutoGenerator mpg = new AutoGenerator(); // 全局配置 GlobalConfig gc = new GlobalConfig(); String projectPath = System.getProperty("user.dir"); gc.setOutputDir(projectPath + "/src/main/java"); gc.setAuthor("aqian666");//作者名称 gc.setOpen(false); // gc.setSwagger2(true); 实体属性 Swagger2 注解 gc.setFileOverride(true); gc.setActiveRecord(false);// 不需要ActiveRecord特性的请改为false gc.setEnableCache(false);// XML 二级缓存 gc.setBaseResultMap(true);// XML ResultMap gc.setBaseColumnList(false);// XML columList gc.setAuthor("aqian666");// 作者 // 自定义文件命名,注意 %s 会自动填充表实体属性! gc.setControllerName("%sController"); gc.setServiceName("%sService"); gc.setServiceImplName("%sServiceImpl"); gc.setMapperName("%sMapper"); gc.setXmlName("%sMapper"); mpg.setGlobalConfig(gc); // 数据源配置 DataSourceConfig dsc = new DataSourceConfig(); dsc.setUrl("jdbc:mysql://localhost:3306/basics?useUnicode=true&useSSL=false&characterEncoding=utf8&serverTimezone=UTC&rewriteBatchedStatements=true"); // dsc.setSchemaName("public"); dsc.setDriverName("com.mysql.cj.jdbc.Driver"); // dsc.setDriverName("com.mysql.jdbc.Driver"); //mysql5.6以下的驱动 dsc.setUsername("root"); dsc.setPassword("123456"); mpg.setDataSource(dsc); // 包配置 PackageConfig pc = new PackageConfig(); pc.setParent("com.slhc.basics.core.base"); // pc.setModuleName("dao"); 自定义包名 // pc.setModuleName("dao.Impl"); pc.setMapper("dao");//dao pc.setService("service");//servcie pc.setController("controller");//controller pc.setEntity("pojo"); // 自定义配置 InjectionConfig cfg = new InjectionConfig() { @Override public void initMap() { // to do nothing } }; // 如果模板引擎是 freemarker String templatePath = "/templates/mapper.xml.ftl"; // 如果模板引擎是 velocity // String templatePath = "/templates/mapper.xml.vm"; // 自定义输出配置 List<FileOutConfig> focList = new ArrayList<>(); // 自定义配置会被优先输出 focList.add(new FileOutConfig(templatePath) { @Override public String outputFile(TableInfo tableInfo) { // 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!! /* return projectPath + "/src/main/resources/mappers/" + pc.getModuleName() + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;*/ //根据自己的位置修改 return projectPath + "/src/main/resources/mappers/" +tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML; } }); /* cfg.setFileCreate(new IFileCreate() { @Override public boolean isCreate(ConfigBuilder configBuilder, FileType fileType, String filePath) { // 判断自定义文件夹是否需要创建 checkDir("调用默认方法创建的目录"); return false; } }); */ mpg.setPackageInfo(pc); cfg.setFileOutConfigList(focList); mpg.setCfg(cfg); // 配置模板 TemplateConfig templateConfig = new TemplateConfig(); // 配置自定义输出模板 //指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别 // templateConfig.setEntity("templates/entity2.java"); // templateConfig.setService(); // templateConfig.setController(); //此处设置为null,就不会再java下创建xml的文件夹了 templateConfig.setXml(null); mpg.setTemplate(templateConfig); // 策略配置 StrategyConfig strategy = new StrategyConfig(); strategy.setNaming(NamingStrategy.underline_to_camel); strategy.setColumnNaming(NamingStrategy.underline_to_camel); //strategy.setSuperEntityClass("com.baomidou.ant.common.BaseEntity"); strategy.setEntityLombokModel(true); strategy.setRestControllerStyle(true); // 公共父类 //strategy.setSuperControllerClass("com.baomidou.ant.common.BaseController"); // 写于父类中的公共字段 //strategy.setSuperEntityColumns("id"); //表名 strategy.setInclude("t_test"); strategy.setControllerMappingHyphenStyle(true); //根据你的表名来建对应的类名,如果你的表名没有什么下划线,比如test,那么你就可以取消这一步 strategy.setTablePrefix("t_"); mpg.setStrategy(strategy); mpg.setTemplateEngine(new FreemarkerTemplateEngine()); mpg.execute(); } }
花了小弟半天时间,终于整对了,csdn查出来的这个,生成的代码都不是我想要的,位置不对,尤其xml的位置。
https://mp.baomidou.com 给大伙贴上,官网的教程,官网的教程吧,也可生成,需要你手动输入包名,这个很
累的。
注意,经过本帅的深度研究!因为本帅可能是习惯聚合项目了,控制层,业务层,数据层,三个要聚合一下,可能某些大佬觉得,你这不是闲的蛋疼吗?有必要吗、、、的确!没必要,但这就是本帅的一直以来的习惯,也是我入门师傅传授的!在我的研究下,我把上边的自动生成改成了自定义生成!
我把代码贴上来,方便与我一样有聚合怪癖的 牛牛修改!
package com.example.config.mybatiesplus; import com.baomidou.mybatisplus.core.toolkit.StringPool; import com.baomidou.mybatisplus.generator.AutoGenerator; import com.baomidou.mybatisplus.generator.InjectionConfig; import com.baomidou.mybatisplus.generator.config.*; import com.baomidou.mybatisplus.generator.config.po.TableInfo; import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy; import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine; import java.io.File; import java.util.ArrayList; import java.util.List; /** * * @ClassName: CodeGeneration * @Description: 代码生成器 * @author aqian666 * @date 2019年7月2日14:08:37 */ public class CodeGenerator { public static void main(String[] args) { // 代码生成器 AutoGenerator mpg = new AutoGenerator(); // 数据源配置 DataSourceConfig dsc = new DataSourceConfig(); dsc.setUrl("jdbc:mysql://localhost:3306/q_role?useUnicode=true&useSSL=false&characterEncoding=utf8&serverTimezone=UTC&rewriteBatchedStatements=true"); // dsc.setSchemaName("public"); dsc.setDriverName("com.mysql.cj.jdbc.Driver"); // dsc.setDriverName("com.mysql.jdbc.Driver"); //mysql5.6以下的驱动 dsc.setUsername("root"); dsc.setPassword("123456"); mpg.setDataSource(dsc); // 全局配置 GlobalConfig gc = new GlobalConfig(); String projectPath = System.getProperty("user.dir"); // gc.setOutputDir(projectPath + "/src/main/java"); gc.setAuthor("aqian666");//作者名称 gc.setOpen(false); // 自定义文件命名,注意 %s 会自动填充表实体属性! // gc.setControllerName("%sController"); gc.setServiceName("%sService"); gc.setServiceImplName("%sServiceImpl"); gc.setMapperName("%sMapper"); gc.setXmlName("%sMapper"); mpg.setGlobalConfig(gc); // gc.setSwagger2(true); 实体属性 Swagger2 注解 gc.setFileOverride(true); gc.setActiveRecord(false);// 不需要ActiveRecord特性的请改为false gc.setEnableCache(false);// XML 二级缓存 gc.setBaseResultMap(true);// XML ResultMap gc.setBaseColumnList(false);// XML columList gc.setAuthor("aqian666");// 作者 // 包配置 PackageConfig pc = new PackageConfig(); pc.setParent("com.example"); // pc.setModuleName("model名"); 自定义包名 pc.setMapper("dao");//dao pc.setService("service");//servcie pc.setController("controller");//controller pc.setEntity("entity"); // 自定义配置 InjectionConfig cfg = new InjectionConfig() { @Override public void initMap() { } }; // 模板引擎是 freemarker // 自定义controller的代码模板 // 如果模板引擎是 velocity // String templatePath = "/templates/mapper.xml.vm"; String templatePath = "/templates/mapper.xml.ftl"; // 自定义输出配置 List<FileOutConfig> focList = new ArrayList<>(); // 自定义配置会被优先输出,配置mapper.xml focList.add(new FileOutConfig(templatePath) { @Override public String outputFile(TableInfo tableInfo) { // 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!! /* return projectPath + "/src/main/resources/mappers/" + pc.getModuleName() + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;*/ //根据自己的位置修改 return projectPath + "/boot-dao/src/main/resources/mappers/" +tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML; } }); //控制层 templatePath = "/templates/controller.java.ftl"; // 自定义配置会被优先输出 focList.add(new FileOutConfig(templatePath) { @Override public String outputFile(TableInfo tableInfo) { // 自定义输出文件名 + pc.getModuleName() String expand = projectPath + "/boot-web/src/main/java/com/example/" + "controller"; String entityFile = String.format((expand + File.separator + "%s" + ".java"), tableInfo.getControllerName()); return entityFile; } }); //业务层 templatePath = "/templates/service.java.ftl"; // 自定义配置会被优先输出 focList.add(new FileOutConfig(templatePath) { @Override public String outputFile(TableInfo tableInfo) { // 自定义输出文件名 + pc.getModuleName() String expand = projectPath + "/boot-service/src/main/java/com/example/" + "service"; String entityFile = String.format((expand + File.separator + "%s" + ".java"), tableInfo.getServiceName()); return entityFile; } }); templatePath = "/templates/serviceImpl.java.ftl"; // 自定义配置会被优先输出 focList.add(new FileOutConfig(templatePath) { @Override public String outputFile(TableInfo tableInfo) { // 自定义输出文件名 + pc.getModuleName() String expand = projectPath + "/boot-service/src/main/java/com/example/" + "service/impl"; String entityFile = String.format((expand + File.separator + "%s" + ".java"), tableInfo.getServiceImplName()); return entityFile; } }); //数据层 templatePath = "/templates/mapper.java.ftl"; // 自定义配置会被优先输出 focList.add(new FileOutConfig(templatePath) { @Override public String outputFile(TableInfo tableInfo) { // 自定义输出文件名 + pc.getModuleName() String expand = projectPath + "/boot-dao/src/main/java/com/example/"+"mapper"; String entityFile = String.format((expand + File.separator + "%s" + ".java"), tableInfo.getMapperName()); return entityFile; } }); //数据层 templatePath = "/templates/entity.java.ftl"; // 自定义配置会被优先输出 focList.add(new FileOutConfig(templatePath) { @Override public String outputFile(TableInfo tableInfo) { // 自定义输出文件名 + pc.getModuleName() String expand = projectPath + "/boot-dao/src/main/java/com/example/"+"entity"; String entityFile = String.format((expand + File.separator + "%s" + ".java"), tableInfo.getEntityName()); return entityFile; } }); /* cfg.setFileCreate(new IFileCreate() { @Override public boolean isCreate(ConfigBuilder configBuilder, FileType fileType, String filePath) { // 判断自定义文件夹是否需要创建 checkDir("调用默认方法创建的目录"); return false; } }); */ mpg.setPackageInfo(pc); cfg.setFileOutConfigList(focList); mpg.setCfg(cfg); // 配置模板 TemplateConfig templateConfig = new TemplateConfig(); // 配置自定义输出模板 //指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别 // templateConfig.setEntity("templates/1.java"); // templateConfig.setService(); templateConfig.setController(null); //此处设置为null,就不会再java下创建xml的文件夹了 templateConfig.setXml(null); mpg.setTemplate(templateConfig); // 策略配置 StrategyConfig strategy = new StrategyConfig(); strategy.setNaming(NamingStrategy.underline_to_camel); strategy.setColumnNaming(NamingStrategy.underline_to_camel); //strategy.setSuperEntityClass("com.baomidou.ant.common.BaseEntity"); strategy.setEntityLombokModel(true); strategy.setRestControllerStyle(true); // 公共父类 //strategy.setSuperControllerClass("com.baomidou.ant.common.BaseController"); // 写于父类中的公共字段 //strategy.setSuperEntityColumns("id"); //表名 strategy.setInclude("t_role"); strategy.setControllerMappingHyphenStyle(true); //根据你的表名来建对应的类名,如果你的表名没有什么下划线,比如test,那么你就可以取消这一步 strategy.setTablePrefix("t_"); mpg.setStrategy(strategy); mpg.setTemplateEngine(new FreemarkerTemplateEngine()); mpg.execute(); } }
值得注意的是,你想要自动生成代码,你的pom.xml中需要引入,下边这些官网都是有的哦!
<!-- mybatis-plus begin --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.1.2</version> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-generator</artifactId> <version>3.1.2</version> </dependency>
<dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.0.1</version> </dependency>
<!-- 模板引擎mybaties-plus 代码生成 --> <dependency> <groupId>org.apache.velocity</groupId> <artifactId>velocity-engine-core</artifactId> <version>2.0</version> </dependency> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.28</version> </dependency> <dependency> <groupId>com.ibeetl</groupId> <artifactId>beetl</artifactId> <version>3.0.7.RELEASE</version> </dependency> <!-- mybatis-plus end -->
你还得注入一个bean!
@Configuration public class MybatisPlusConfig { @Bean public PaginationInterceptor paginationInterceptor(){ PaginationInterceptor page = new PaginationInterceptor(); //设置方言类型 page.setDialectType("mysql"); return page; } }
yml里还需要配置!!!
mybatis-plus: mapper-locations: classpath:mappers/*Mapper.xml type-aliases-package: com.example.springbootdemo.bean.pojo configuration: # 这个配置会将执行的sql打印出来,在开发或测试的时候可以用 log-impl: org.apache.ibatis.logging.stdout.StdOutImpl global-config: # 逻辑删除配置 logic-delete-value: 0 logic-not-delete-value: 1
最后我说一下mybaties的好处,就我个人理解,更加人性化,有习惯hibernate的同袍——他们比较懒,不喜欢写sql,有喜欢mybaties的同袍,比如我——他们比较蠢,每次改变一个参数,就得新写一个方法。so,plus结合俩者的优点,而且代码生成器文档中有提到,你可以自己定义基础方法哦!
另外mybaties这个起名字真的没谁了,起了个plus。。。有个电影叫大佛普拉斯,推荐一下!有问题请联系我!
评论
最近浏览
opq221 LV5
2023年3月22日
杭哥哥 LV1
2022年6月8日
ningshu110 LV6
2022年3月30日
928463775
2022年2月9日
暂无贡献等级
best2018 LV46
2021年12月31日
ryanzzz
2021年10月12日
暂无贡献等级
yulawrence
2021年7月29日
暂无贡献等级
yujiaqi
2021年7月28日
暂无贡献等级
浪矢claireX LV1
2021年7月14日
zhengchenghui LV5
2021年6月23日