mybatis-plus DTO代码自动生成

import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.*;
import com.baomidou.mybatisplus.generator.config.builder.ConfigBuilder;
import com.baomidou.mybatisplus.generator.config.rules.DbType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import org.springframework.util.StringUtils;

import java.util.Map;

/**
 * 

* 代码生成器演示 *

*/ public class MpGenerator { //数据库用户名密码 private static String username="sps_spsdb_user"; private static String password="wEeqqmoi"; //表前缀,不需要则写空 private static String tablePrefix="tb_"; //数据库连接url private static String dbUrl="jdbc:postgresql://10.19.131.178:7017/sps_spsdb?useUnicode=true&characterEncoding=UTF-8"; /** * 如要使用该代码生成工具,请将该jar包添加到 pom文件中, * 否则会出现:java.lang.NoClassDefFoundError: org/apache/velocity/context/Context * (生成完之后也建议把该jar包去掉,工程代码瘦身) * * org.apache.velocity * velocity-engine-core * * @param args */ public static void main(String[] args) { AutoGenerator mpg = new AutoGenerator(); String outPut="D:\\output\\"; // String outPut="E:\\intellij_workspace\\mybatis-test2\\main-bussiness\\src\\main\\"; if(StringUtils.isEmpty(outPut)){ throw new RuntimeException("输出目录不能为空!"); } // 全局配置 GlobalConfig gc = new GlobalConfig(); gc.setOutputDir(outPut+"java"); gc.setFileOverride(true); gc.setActiveRecord(true);// 不需要ActiveRecord特性的请改为false gc.setEnableCache(false);// XML 二级缓存 gc.setBaseResultMap(true);// XML ResultMap gc.setBaseColumnList(false);// XML columList // .setKotlin(true) 是否生成 kotlin 代码 gc.setAuthor("auto-genergator"); // 自定义文件命名,注意 %s 会自动填充表实体属性! // gc.setMapperName("%sDao"); // gc.setXmlName("%sDao"); // gc.setServiceName("MP%sService"); // gc.setServiceImplName("%sServiceDiy"); // gc.setControllerName("%sAction"); mpg.setGlobalConfig(gc); // 数据源配置 DataSourceConfig dsc = new DataSourceConfig(); // dsc.setDbType(DbType.MYSQL); // dsc.setTypeConvert(new MySqlTypeConvert(){ // // 自定义数据库表字段类型转换【可选】 // @Override // public DbColumnType processTypeConvert(String fieldType) { // System.out.println("转换类型:" + fieldType); // // 注意!!processTypeConvert 存在默认类型转换,如果不是你要的效果请自定义返回、非如下直接返回。 // return super.processTypeConvert(fieldType); // } // }); dsc.setDbType(DbType.POSTGRE_SQL); dsc.setDriverName("org.postgresql.Driver"); dsc.setUsername(username); dsc.setPassword(password); dsc.setUrl(dbUrl); mpg.setDataSource(dsc); // 策略配置 StrategyConfig strategy = new StrategyConfig(); // strategy.setCapitalMode(true);// 全局大写命名 ORACLE 注意 strategy.setTablePrefix(new String[] {tablePrefix});// 此处可以修改为您的表前缀 strategy.setNaming(NamingStrategy.underline_to_camel);// 表名生成策略 strategy.setEntityColumnConstant(true); //strategy.setInclude(new String[] { "tb_widget" }); // 需要生成的表 // strategy.setExclude(new String[]{"test"}); // 排除生成的表 // 自定义实体父类 // strategy.setSuperEntityClass("com.baomidou.demo.TestEntity"); // 自定义实体,公共字段 // strategy.setSuperEntityColumns(new String[] { "test_id", "age" }); // 自定义 mapper 父类 // strategy.setSuperMapperClass("com.baomidou.demo.TestMapper"); // 自定义 service 父类 // strategy.setSuperServiceClass("com.baomidou.demo.TestService"); // 自定义 service 实现类父类 // strategy.setSuperServiceImplClass("com.baomidou.demo.TestServiceImpl"); // 自定义 controller 父类 // strategy.setSuperControllerClass("com.baomidou.demo.TestController"); // 【实体】是否生成字段常量(默认 false) // public static final String ID = "test_id"; // strategy.setEntityColumnConstant(true); // 【实体】是否为构建者模型(默认 false) // public User setName(String name) {this.name = name; return this;} // strategy.setEntityBuilderModel(true); // strategy.setSuperMapperClass("com.hikvision.energy.") mpg.setStrategy(strategy); // 包配置 PackageConfig pc = new PackageConfig(); pc.setParent("com.hikvision.energy.portal"); pc.setEntity("entity"); pc.setMapper("mapper"); pc.setService("service"); pc.setController("controller"); mpg.setPackageInfo(pc); // 注入自定义配置,可以在 VM 中使用 cfg.abc 【可无】 // InjectionConfig cfg = new InjectionConfig() { // @Override // public void initMap() { // Map map = new HashMap(); // map.put("abc", this.getConfig().getGlobalConfig().getAuthor() + "-mp"); // this.setMap(map); // } // }; // 自定义 xxList.jsp 生成 // List focList = new ArrayList(); // focList.add(new FileOutConfig("/template/list.jsp.vm") { // @Override // public String outputFile(TableInfo tableInfo) { // // 自定义输入文件名称 // return "D://my_" + tableInfo.getEntityName() + ".jsp"; // } // }); // cfg.setFileOutConfigList(focList); // mpg.setCfg(cfg); // // // 调整 xml 生成目录演示 // focList.add(new FileOutConfig("/templates/mapper.xml.vm") { // @Override // public String outputFile(TableInfo tableInfo) { // return "/develop/code/xml/" + tableInfo.getEntityName() + ".xml"; // } // }); // cfg.setFileOutConfigList(focList); // mpg.setCfg(cfg); // // // 关闭默认 xml 生成,调整生成 至 根目录 // TemplateConfig tc = new TemplateConfig(); // tc.setXml(null); // mpg.setTemplate(tc); // 自定义模板配置,可以 copy 源码 mybatis-plus/src/main/resources/templates 下面内容修改, // 放置自己项目的 src/main/resources/templates 目录下, 默认名称一下可以不配置,也可以自定义模板名称 TemplateConfig tc = new TemplateConfig(); tc.setController(null); // tc.setEntity("..."); // tc.setMapper("..."); // tc.setXml("..."); // tc.setService("..."); // tc.setServiceImpl("..."); // 如上任何一个模块如果设置 空 OR Null 将不生成该模块。 // mpg.setTemplate(tc); // 执行生成 mpg.setConfig(new ConfigBuilder(pc,dsc,strategy,tc,gc)); ConfigBuilder config = mpg.getConfig(); Map pathInfo = config.getPathInfo(); //目录设置修改 pathInfo.put(ConstVal.XML_PATH,outPut+"resources/mapper/"); mpg.execute(); // 打印注入设置【可无】 // System.err.println(mpg.getCfg().getMap().get("abc")); } }

你可能感兴趣的:(mybatis)