首页 > 编程知识 正文

代码生成,mybatis代码生成器动态部署

时间:2023-05-05 03:00:18 阅读:20315 作者:2660

Mybatis-Plus代码生成器有时我们拿到数据库,写接口很累。 毕竟,十多个数据库、各个接口必须重复写,pojo层、服务层等信息是否有点不耐烦? 所以我的Mybatis-Plus代码生成器就是为了解决这个。

1 .添加依赖! --Mybatis-Plus生成器是--dependencygroupidcom.Bao midou/groupidartifactidmybatis-plus-generator/依赖artifactidversion3.-- freemarker模板引擎(未使用本机模板引擎)---dependencygroupidorg.freemarker/grooup artifactidversion2.3. 31-- my bits-plus---dependencygroupidcom.Bao midou/groupidartifactidmybatis-plus-boous artifactidversion3- -依赖于MySQL--从属cygroupidmysql/groupidartifactidmysql-connector-Java/artifactidversion8.

package com.assiainfo.wiki; import com.Bao midou.mybatisplus.core.exceptions.mybatisplusexception; import com.Bao midou.mybatisplus.core.toolkit.stringpool; import com.Bao midou.mybatisplus.core.toolkit.string utils; import com.Bao midou.mybatisplus.generator.auto generator; import com.Bao midou.mybatisplus.generator.injection config; import com.Bao midou.mybatisplus.generator.config.*; import com.Bao midou.mybatisplus.generator.config.po.tableinfo; import com.Bao midou.mybatisplus.generator.config.rules.naming strategy; import com.Bao midou.mybatisplus.generator.engine.freemarkertemplateengine; import java.util.ArrayList; import java.util.List; import java.util.Scanner; 读取publicclassmybatisgenerator {/* * * p *控制台内容的*/p */publicstaticstringscanner (stringtip )扫描仪=new scanner help.append ('请输入' tip ':'; system.out.println (help.tostring ); 扫码

er.hasNext()) { String ipt = scanner.next(); if (StringUtils.isNotBlank(ipt)) { return ipt; } } throw new MybatisPlusException("请输入正确的" + tip + "!"); } public static void main(String[] args) { // 代码生成器 AutoGenerator mpg = new AutoGenerator(); // 全局配置 GlobalConfig gc = new GlobalConfig(); final String projectPath = System.getProperty("user.dir"); gc.setOutputDir(projectPath + "/src/main/java"); //作者 gc.setAuthor("wsw"); //打开输出目录 gc.setOpen(false); //xml开启 BaseResultMap gc.setBaseResultMap(true); //xml开启 BaseColumnList gc.setBaseColumnList(true); //实体属性 Swagger2 注解 gc.setSwagger2(true); mpg.setGlobalConfig(gc); // 数据源配置 DataSourceConfig dsc = new DataSourceConfig(); dsc.setUrl("jdbc:mysql://localhost:3306/bookstore?useUnicode=true&深情的故事=utf-8&useSSL=true&serverTimezone=UTC"); // dsc.setSchemaName("public"); //注意:数据库必须要有对应的字段和表,不然不能自动识别 dsc.setDriverName("com.mysql.cj.jdbc.Driver"); dsc.setUsername("root"); dsc.setPassword("123456"); mpg.setDataSource(dsc); // 包配置 final PackageConfig pc = new PackageConfig();// pc.setModuleName(scanner("模块名")); pc.setParent("com.assiainfo.wiki") .setEntity("pojo") .setMapper("mapper") .setService("service") .setServiceImpl("service.impl") .setController("controller"); 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/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML; } }); cfg.setFileOutConfigList(focList); mpg.setCfg(cfg); // 配置模板 TemplateConfig templateConfig = new TemplateConfig(); // 配置自定义输出模板 //指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别 // templateConfig.setEntity("templates/entity2.java"); // templateConfig.setService(); // templateConfig.setController(); templateConfig.setXml(null); mpg.setTemplate(templateConfig); // 策略配置 StrategyConfig strategy = new StrategyConfig(); strategy.setNaming(NamingStrategy.underline_to_camel); strategy.setColumnNaming(NamingStrategy.no_change);// strategy.setSuperEntityClass("你自己的父类实体,没有就不用设置!"); strategy.setEntityLombokModel(true); // 公共父类// strategy.setSuperControllerClass("你自己的父类控制器,没有就不用设置!"); // 写于父类中的公共字段// strategy.setSuperEntityColumns("id"); //生成@RestController 控制器 strategy.setRestControllerStyle(true); strategy.setInclude(scanner("表名,多个英文逗号分割").split(",")); strategy.setControllerMappingHyphenStyle(true); //表前缀 strategy.setTablePrefix(pc.getModuleName() + "_"); mpg.setStrategy(strategy); mpg.setTemplateEngine(new FreemarkerTemplateEngine()); mpg.execute(); }} 3.运行结果为:(这些包和类都是自动添加的)

看一下类里面的代码是否对应:

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。