• MyabtisPlus逆向工程


    MyabtisPlus逆向工程

    今天写一个后台管理系统时,突然想试试MybatisPlus的逆向工程,所以写一篇随笔来记录一下.

    推荐大家去看MybatisPlus官网的介绍.因为本人不做深入分析,只是记录一下.

    导入依赖

    <!--添加 代码生成器 依赖-->
            <dependency>
                <groupId>com.baomidou</groupId>
                <artifactId>mybatis-plus-generator</artifactId>
                <version>3.1.1</version>
            </dependency>
            <dependency>
                <groupId>org.apache.velocity</groupId>
                <artifactId>velocity-engine-core</artifactId>
                <version>2.1</version>
            </dependency>
            <dependency>
                <groupId>org.freemarker</groupId>
                <artifactId>freemarker</artifactId>
                <version>2.3.28</version>
            </dependency>
    		<dependency>
                <groupId>com.baomidou</groupId>
                <artifactId>mybatis-plus-boot-starter</artifactId>
                <version>3.4.0</version>
            </dependency>
    

    编写代码生成器

    package com.gt.admin;
    
    import com.baomidou.mybatisplus.annotation.DbType;
    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.converts.MySqlTypeConvert;
    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.lang.StringUtils;
    
    import java.util.ArrayList;
    import java.util.List;
    import java.util.Scanner;
    
    public class CodeGenerder {
        /**
         * 读取控制台内容
         */
        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 globalConfig = new GlobalConfig();
            //生成文件的输出目录
            String projectPath = System.getProperty("user.dir");
            globalConfig.setOutputDir(projectPath + "/src/main/java");
            //Author设置作者
            globalConfig.setAuthor("高腾");
            //是否覆盖文件
            globalConfig.setFileOverride(true);
            //生成后打开文件
            globalConfig.setOpen(false);
            mpg.setGlobalConfig(globalConfig);
    
            /**
             * 数据源配置
             */
            DataSourceConfig dataSourceConfig = new DataSourceConfig();
            // 数据库类型,默认MYSQL
            dataSourceConfig.setDbType(DbType.MYSQL);
            //自定义数据类型转换
            dataSourceConfig.setTypeConvert(new MySqlTypeConvert());
            dataSourceConfig.setUrl("jdbc:mysql://47.94.155.85:3306/imooc_video_dev?characterEncoding=utf-8&serverTimezone=GMT%2B8&useSSL=false");
            dataSourceConfig.setDriverName("com.mysql.jdbc.Driver");
            dataSourceConfig.setUsername("root");
            dataSourceConfig.setPassword("root");
            mpg.setDataSource(dataSourceConfig);
    
            /**
             * 包配置
             */
            PackageConfig pc = new PackageConfig();
            pc.setModuleName(scanner("模块名"));
            //父包名。如果为空,将下面子包名必须写全部, 否则就只需写子包名
            pc.setParent("com.gt");
            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.underline_to_camel);
            strategy.setInclude(scanner("表名,多个英文逗号分割").split(","));
            //实体是否为lombok模型(默认 false)
            strategy.setEntityLombokModel(true);
            //生成 @RestController 控制器
            strategy.setRestControllerStyle(true);
            //设置自定义继承的Entity类全称,带包名
            //strategy.setSuperEntityClass("com.jiangfeixiang.mpdemo.BaseEntity");
            //设置自定义继承的Controller类全称,带包名
            //strategy.setSuperControllerClass("com.jiangfeixiang.mpdemo.BaseController");
            //设置自定义基础的Entity类,公共字段
            //strategy.setSuperEntityColumns("id");
            //驼峰转连字符
            strategy.setControllerMappingHyphenStyle(true);
            //表名前缀
            strategy.setTablePrefix(pc.getModuleName() + "_");
            mpg.setStrategy(strategy);
            mpg.setTemplateEngine(new FreemarkerTemplateEngine());
            mpg.execute();
        }
    }
    
    

    测试

    此篇随笔参考以下博客:

    [springboot整合mybatis-plus逆向工程](https://www.cnblogs.com/smfx1314/p/10849321.html)

    在此,特别感谢!

  • 相关阅读:
    Windows Server 2008 R2 实现多用户连接远程桌面
    增加远程登录用户登陆个数
    Win2008R2PHP5.4环境加载Zend模块
    Windows 和  Linux 下 禁止ping的方法
    Windows 2003 FastCgi安装环境
    Windows2008下搭建NFS实现windows空间提供linux使用
    Spring + JdbcTemplate + JdbcDaoSupport examples
    Spring Object/XML mapping example
    Spring AOP + AspectJ in XML configuration example
    Spring AOP + AspectJ annotation example
  • 原文地址:https://www.cnblogs.com/gttttttt/p/13634304.html
Copyright © 2020-2023  润新知