| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- package com.yt.zhylplat;
- import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
- import com.baomidou.mybatisplus.core.toolkit.StringPool;
- import com.baomidou.mybatisplus.core.toolkit.StringUtils;
- import com.baomidou.mybatisplus.generator.AutoGenerator;
- import com.baomidou.mybatisplus.generator.InjectionConfig;
- import com.baomidou.mybatisplus.generator.config.*;
- import com.baomidou.mybatisplus.generator.config.builder.ConfigBuilder;
- import com.baomidou.mybatisplus.generator.config.converts.MySqlTypeConvert;
- import com.baomidou.mybatisplus.generator.config.converts.OracleTypeConvert;
- import com.baomidou.mybatisplus.generator.config.po.TableInfo;
- import com.baomidou.mybatisplus.generator.config.rules.DbColumnType;
- import com.baomidou.mybatisplus.generator.config.rules.FileType;
- import com.baomidou.mybatisplus.generator.config.rules.IColumnType;
- import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
- import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
- import java.util.ArrayList;
- import java.util.List;
- import java.util.Scanner;
- /**
- * <p>
- * 读取控制台内容
- * </p>
- */
- public class CodeGenerator {
- /**
- * <p>
- * 读取控制台内容
- * </p>
- */
- public static String scanner(String tip) {
- Scanner scanner = new Scanner(System.in);
- StringBuilder help = new StringBuilder();
- help.append("请输入表名:");
- 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("YTKJ");
- gc.setFileOverride(true);//是否覆盖原本存在的文件
- // gc.setAuthor("wuxiongwei");
- gc.setOpen(false);
- gc.setSwagger2(true); //实体属性增加 Swagger2 注解
- gc.setServiceName("%sService");//更改service 生成名称
- mpg.setGlobalConfig(gc);
- // 数据源配置
- DataSourceConfig dsc = new DataSourceConfig();
- dsc.setUrl("jdbc:mysql://192.168.1.200:3306/zhyl_db_jz?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&useSSL=false&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true&nullCatalogMeansCurrent=true");
- // dsc.setSchemaName("public");
- dsc.setDriverName("com.mysql.cj.jdbc.Driver");
- dsc.setUsername("root");
- dsc.setPassword("800100");
- dsc.setTypeConvert(new MySqlTypeConvert(){//数据库字段类型转换
- @Override
- public IColumnType processTypeConvert(GlobalConfig globalConfig, String fieldType) {
- if ( fieldType.toLowerCase().contains( "number" ) ) {
- return DbColumnType.INTEGER;
- }
- if ( fieldType.toLowerCase().contains( "datetime" ) ) {
- return DbColumnType.DATE;
- }
- if ( fieldType.toLowerCase().contains( "date" ) ) {
- return DbColumnType.DATE;
- }
- return (DbColumnType) super.processTypeConvert(globalConfig, fieldType);
- }
- });
- mpg.setDataSource(dsc);
- // 包配置
- PackageConfig pc = new PackageConfig();
- // pc.setModuleName(scanner("模块名"));
- pc.setParent("com.yt.zhylplat");
- pc.setMapper("dao"); //设置默认的mapper为dao
- // pc.setService("app.service");
- // pc.setServiceImpl("app.service.impl");
- //pc.setEntity("moduleZhjc.entity");
- // pc.setController("app.controller");
- // pc.setModuleName("moduleDabj");
- mpg.setPackageInfo(pc);
- // 自定义配置
- 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/mapper/null" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;
- }
- });
- /*
- cfg.setFileCreate(new IFileCreate() {
- @Override
- public boolean isCreate(ConfigBuilder configBuilder, FileType fileType, String filePath) {
- // 判断自定义文件夹是否需要创建
- checkDir("调用默认方法创建的目录");
- return false;
- }
- });
- */
- cfg.setFileOutConfigList(focList);
- mpg.setCfg(cfg);
- // 配置模板
- TemplateConfig templateConfig = new TemplateConfig();
- // 配置自定义输出模板
- //指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别
- // templateConfig.setEntity("templates/entity2.java");
- // templateConfig.setService();
- // templateConfig.setController();
- templateConfig.setXml(null);
- //如果不生成对应的后台(service、serviceImpl、controller、mapper)代码,将下面注释打开即可
- // templateConfig.setServiceImpl(null);
- // templateConfig.setService(null);
- // templateConfig.setController(null);
- // templateConfig.setMapper(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.setInclude(scanner("T_Citizen_Suggestion").split(","));
- strategy.setSuperEntityColumns("id");
- strategy.setEntityTableFieldAnnotationEnable(true);//实体类字段加对应数据库字段注解
- strategy.setControllerMappingHyphenStyle(true);
- strategy.setTablePrefix(pc.getModuleName() + "_");
- mpg.setStrategy(strategy);
- mpg.setTemplateEngine(new FreemarkerTemplateEngine());
- mpg.execute();
- }
- }
|