精华内容
下载资源
问答
  • mybatisPlus自动生成代码,详细介绍,需要改动的地方里面有注解,只需要导入相关依赖,简单易懂
  • 主要介绍了使用MyBatisPlus自动生成代码后tomcat运行报错的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
  • mybatisplus自动生成代码 入口类: package com.mbpnj.codegenerator; import com.baomidou.mybatisplus.annotation.DbType; import com.baomidou.mybatisplus.annotation.IdType; import ...

    mybatisplus自动生成代码

    入口类:

    
    package com.mbpnj.codegenerator;
    
    import com.baomidou.mybatisplus.annotation.DbType;
    import com.baomidou.mybatisplus.annotation.IdType;
    import com.baomidou.mybatisplus.generator.AutoGenerator;
    import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
    import com.baomidou.mybatisplus.generator.config.GlobalConfig;
    import com.baomidou.mybatisplus.generator.config.PackageConfig;
    import com.baomidou.mybatisplus.generator.config.StrategyConfig;
    import com.baomidou.mybatisplus.generator.config.rules.DateType;
    import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
    import org.junit.jupiter.api.Test;
    
    public class CodeGenerator {
        @Test
        public void test() {
            // 1、创建代码生成器
            AutoGenerator mpg = new AutoGenerator();
    
            // 2、全局配置
            GlobalConfig gc = new GlobalConfig();
            String projectPath = System.getProperty("user.dir");
            gc.setOutputDir(projectPath + "/src/main/java");
            gc.setAuthor("作者");
            gc.setOpen(false); //生成后是否打开资源管理器
            gc.setFileOverride(false); //重新生成时文件是否覆盖
            gc.setServiceName("%sService"); //去掉Service接口的首字母I
            gc.setIdType(IdType.AUTO); //主键策略
            gc.setDateType(DateType.ONLY_DATE);//定义生成的实体类中日期类型
            gc.setSwagger2(false);//开启Swagger2模式
    
            mpg.setGlobalConfig(gc);
    
            // 3、数据源配置
            DataSourceConfig dsc = new DataSourceConfig();
            dsc.setUrl("jdbc:mysql://ip地址:端口/数据库名");
            dsc.setDriverName("com.mysql.jdbc.Driver");
            dsc.setUsername("账户");
            dsc.setPassword("密码");
            dsc.setDbType(DbType.MYSQL);
            mpg.setDataSource(dsc);
    
            // 4、包配置
            PackageConfig pc = new PackageConfig();
            pc.setModuleName(null); //模块名
            pc.setParent("包的全路径");
            pc.setEntity("entity");
            pc.setService("service");
            pc.setMapper("repository");
            mpg.setPackageInfo(pc);
    
            // 5、策略配置
            StrategyConfig strategy = new StrategyConfig();
            strategy.setInclude("要生成的数据库表");//对那一张表生成代码
            strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略
            strategy.setTablePrefix(pc.getModuleName() + "_"); //生成实体时去掉表前缀
            strategy.entityTableFieldAnnotationEnable(true);//实体属性上添加表字段映射
            strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略
    //        strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作
    
            strategy.setRestControllerStyle(true); //restful api风格控制器
            strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符
    
            mpg.setStrategy(strategy);
    
            // 6、执行
            mpg.execute();
        }
    }
    
    

    pom依赖

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.4.1</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        <groupId>com.mbpnj</groupId>
        <artifactId>codegenerator</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <packaging>war</packaging>
        <name>codegenerator</name>
        <description>Demo project for Spring Boot</description>
    
        <properties>
            <java.version>1.8</java.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-tomcat</artifactId>
                <scope>provided</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
    
            <!--MyBatis-Plus代码生成器需要的依赖,开始-->
            <dependency>
                <groupId>com.baomidou</groupId>
                <artifactId>mybatis-plus-boot-starter</artifactId>
                <version>3.2.0</version>
            </dependency>
    
            <dependency>
                <groupId>com.baomidou</groupId>
                <artifactId>mybatis-plus-generator</artifactId>
                <version>3.2.0</version>
            </dependency>
            <dependency>
                <groupId>org.postgresql</groupId>
                <artifactId>postgresql</artifactId>
                <scope>runtime</scope>
            </dependency>
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <version>5.1.46</version>
            </dependency>
            <dependency>
                <groupId>org.apache.velocity</groupId>
                <artifactId>velocity-engine-core</artifactId>
                <version>2.2</version>
            </dependency>
        </dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    
    </project>
    

    我们在IDE里面直接创建一个maven工程,把依赖和类直接建成,就可以直接使用的,开箱即用

    更多精彩,关注我公号,一起学习、成长

    在这里插入图片描述

    展开全文
  • mybatisPlus自动生成代码

    千次阅读 2020-08-28 17:49:01
    第二,就是一个自动生成代码需要的配置类generatorConfig.properties (修改这个表里的配置可以改变你要生成实体的表名,位置等等) 第三,就是生成器代码 第四,最重要的一步,把我的配置文件改成你的,目录改成...

                         参考文章

    本文完全是参考↑↑参考文章

    通过这个配置可以生成mapper.xml,mapper,serviceImpl,controller等等

    大概介绍一下,主要分为几个部分

    首先,就是依赖

    第二,就是一个自动生成代码需要的配置类generatorConfig.properties (修改这个表里的配置可以改变你要生成实体的表名,位置等等)

    第三,就是生成器代码

    第四,最重要的一步,把我的配置文件改成你的,目录改成你的(如果你不知道怎么改,建议直接在main方法入口打个断点,慢慢调试,就明白了)

    好了,下面开始上代码

    第一,pom中需要加入的依赖

    <!-- mybatisPlus-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-jdbc</artifactId>
            </dependency>
            <dependency>
                <groupId>com.baomidou</groupId>
                <artifactId>mybatis-plus-boot-starter</artifactId>
                <version>${mybatisplus.version}</version>
            </dependency>
            <dependency>
                <groupId>com.baomidou</groupId>
                <artifactId>mybatis-plus-generator</artifactId>
                <version>3.3.2</version>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-freemarker</artifactId>
            </dependency>
    
            <!-- mysql -->
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <scope>runtime</scope>
            </dependency>
    
          <!-- lombok -->
            <dependency>
                <groupId>org.projectlombok</groupId>
                <artifactId>lombok</artifactId>
                <version>${lombok.version}</version>
                <scope>provided</scope>
            </dependency>
    
          <!--swagger 文档-->
            <dependency>
                <groupId>io.springfox</groupId>
                <artifactId>springfox-swagger2</artifactId>
                <version>2.7.0</version>
            </dependency>
            <dependency>
                <groupId>io.springfox</groupId>
                <artifactId>springfox-swagger-ui</artifactId>
                <version>2.7.0</version>
            </dependency>

    (我的项目时多模块项目,我把这个的依赖放在parent的pom.xml中了) 

     

    第二步,自动生成的配置文件 generatorConfig.properties

    generator.jdbc.driverClass=com.mysql.cj.jdbc.Driver
    generator.jdbc.url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8
    generator.jdbc.username=root
    generator.jdbc.password=123456
    
    projectPackage=com.luoyu.service
    #下面两个字段都是从项目名开始填
    outputFilePath=/luoyu-demo-service/src/main/java/com/luoyu/service/
    outputMapXmlFilePath=/luoyu-demo-service/src/main/resources/mapper/
    
    # 表名 多表之间逗号分隔
    tableNames=user
    
    # 包配置
    setMapper=mapper
    setEntity=model
    setService=service
    setController=controller

     对应项目中的位置

     

    第三步、生成器代码 CodeGenerator

    package com.luoyu.service.generator;
    
    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.io.IOException;
    import java.io.InputStream;
    import java.util.ArrayList;
    import java.util.List;
    import java.util.Properties;
    
    /**
     * Project code genertor
     *
     * @author zjx
     */
    public class CodeGenerator {
    
    
        /**
         * Project package
         */
        private static String projectPackage;
    
        private static String outputFilePath;
    
        private static String outputMapXmlFilePath;
    
        private static String tableNames;
    
        /**
         * 包配置
         */
        private static String setMapper;
        private static String setEntity;
        private static String setService;
        private static String setController;
    
        /**
         * Database url
         */
        private static String url;
        /**
         * Database username
         */
        private static String username;
        /**
         * Database password
         */
        private static String password;
        /**
         * Database driver class
         */
        private static String driverClass;
    
        /**
         * 文件名后缀
         */
        private static String fileSuffix = ".java";
    
        /**
         * Init database information
         */
        static {
            Properties properties = new Properties();
            InputStream i = CodeGenerator.class.getResourceAsStream("/generatorConfig.properties");
            try {
                properties.load(i);
                url = properties.getProperty("generator.jdbc.url").trim();
                username = properties.getProperty("generator.jdbc.username").trim();
                password = properties.getProperty("generator.jdbc.password").trim();
                driverClass = properties.getProperty("generator.jdbc.driverClass").trim();
                projectPackage = properties.getProperty("projectPackage").trim();
                outputFilePath = properties.getProperty("outputFilePath").trim();
                outputMapXmlFilePath = properties.getProperty("outputMapXmlFilePath").trim();
                tableNames = properties.getProperty("tableNames").trim();
                setMapper = properties.getProperty("setMapper").trim();
                setEntity = properties.getProperty("setEntity").trim();
                setService = properties.getProperty("setService").trim();
                setController = properties.getProperty("setController").trim();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    
        /**
         * main method, execute code generator
         */
        public static void main(String[] args) {
            String projectPath = System.getProperty("user.dir");
    
            String javaPath = projectPackage.replaceAll("\\.", "/");
            // 代码生成器
            AutoGenerator mpg = new AutoGenerator();
    
            // 全局配置
            GlobalConfig gc = new GlobalConfig();
            gc.setAuthor("luoyu");
    //        gc.setOpen(false); // 是否打开输出目录,设置为true就是直接弹出生成的文件目录
    //        gc.setOutputDir(projectPath + "/src/main/java"); // 输出文件目录
            gc.setFileOverride(false); // 是否覆盖已有文件
            gc.setSwagger2(true);  // 实体属性 Swagger2 注解
            gc.setMapperName("%sMapper");
            gc.setXmlName("%sMapper");
            gc.setServiceName("%sService");
            gc.setServiceImplName("%sServiceImpl");
            gc.setBaseResultMap(true); // mapper.xml中生成BaseResultMap
            gc.setActiveRecord(true);
            gc.setBaseColumnList(true);
    
            mpg.setGlobalConfig(gc);
    
            // 数据源配置
            DataSourceConfig dsc = new DataSourceConfig();
            dsc.setUrl(url.trim());
            //dsc.setSchemaName("public");
            dsc.setUsername(username.trim());
            dsc.setPassword(password.trim());
            dsc.setDriverName(driverClass.trim());
    
            mpg.setDataSource(dsc);
    
            // 包配置
            PackageConfig pc = new PackageConfig();
            pc.setParent(projectPackage.trim());
            //pc.setModuleName("model名"); 自定义包名
            pc.setMapper(setMapper.trim());
            pc.setEntity(setEntity.trim());
            pc.setService(setService.trim());
            pc.setController(setController.trim());
            mpg.setPackageInfo(pc);
    
            // 自定义配置
            InjectionConfig cfg = new InjectionConfig() {
                @Override
                public void initMap() {
                    // to do nothing
                }
            };
    
            // 自定义输出配置
            List<FileOutConfig> focList = new ArrayList<>();
    
            /**mapper xml文件*/
            // 如果模板引擎是 freemarker
            String templatePath = "/templates/mapper.xml.ftl";
            // 自定义配置会被优先输出
            focList.add(new FileOutConfig(templatePath) {
    
                @Override
                public String outputFile(TableInfo tableInfo) {
                    // 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!!
                    return projectPath + outputMapXmlFilePath + 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 + outputFilePath + "controller";
                    String entityFile = String.format(expand + File.separator + "%s" + fileSuffix, 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 + outputFilePath + "service";
                    String entityFile = String.format(expand + File.separator + "%s" + fileSuffix, 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 + outputFilePath + "service/impl";
                    String entityFile = String.format(expand + File.separator + "%s" + fileSuffix, tableInfo.getServiceImplName());
                    return entityFile;
                }
            });
    
            /**数据mapper层*/
            templatePath = "/templates/mapper.java.ftl";
            // 自定义配置会被优先输出
            focList.add(new FileOutConfig(templatePath) {
                @Override
                public String outputFile(TableInfo tableInfo) {
                    // 自定义输出文件名 + pc.getModuleName()
                    String expand = projectPath + outputFilePath + "mapper";
                    String entityFile = String.format(expand + File.separator + "%s" + fileSuffix, tableInfo.getMapperName());
                    return entityFile;
                }
            });
    
            /**数据entity层*/
            templatePath = "/templates/entity.java.ftl";
            // 自定义配置会优先输出
            focList.add(new FileOutConfig(templatePath) {
                @Override
                public String outputFile(TableInfo tableInfo) {
                    // 自定义输出文件名 + pc.getModuleName()
                    String expand = projectPath + outputFilePath + "model";
                    String entityFile = String.format(expand + File.separator + "%s" + fileSuffix, tableInfo.getEntityName());
                    return entityFile;
                }
            });
    
    		/*cfg.setFileOutConfigList(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();
            templateConfig.setController(null);
            templateConfig.setXml(null);
            mpg.setTemplate(templateConfig);
    
            // 策略配置
            StrategyConfig strategy = new StrategyConfig();
            strategy.setNaming(NamingStrategy.underline_to_camel);
            strategy.setColumnNaming(NamingStrategy.underline_to_camel);
            //strategy.setSuperEntityClass("");
            strategy.setEntityLombokModel(true);
            strategy.setRestControllerStyle(true);
            //strategy.setExclude("");
            // 表名
            strategy.setInclude(tableNames.split(","));
            strategy.setControllerMappingHyphenStyle(true);
            /**表前缀,要自动去除添加*/
            //strategy.setTablePrefix("t_");
    
            mpg.setStrategy(strategy);
            mpg.setTemplateEngine(new FreemarkerTemplateEngine());
    
            mpg.execute();
        }
    }
    
    

    我放在项目中的对应位置

     第四步、记得去修改成你本地的对应配置哦 

    需要修改的地方

    1.generatorConfig.properties

    2.codeGenerator中类似于下图圈中的地方(就是实际配置目录的地方)

    好了,记录一下,以防以后现找,正好大家一起学习

    展开全文
  • MybatisPlus代码自动生成器 AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码,极大的提升了开发效率。 ...

    MybatisPlus代码自动生成器

    AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码,极大的提升了开发效率。

        public static void main(String[] args) {
            //构建一个代码自动生成器对象
            AutoGenerator mpg = new AutoGenerator();
    
            /**
             * 配置策略
             */
    
            /**1.全局配置,一定要是mybatisplus.generation下的GlobalConfig
             */
            GlobalConfig gc = new GlobalConfig();
            String propertyPath = System.getProperty("user.dir");  //获取当前的用户目录并添加到全球配置中
            System.out.println("用户目录propertyPath="+propertyPath);
            gc.setOutputDir(propertyPath+"/src/main/java");   //设置输出目录
            gc.setAuthor("Leon");   //设置作者
            gc.setOpen(false);  //设置生成完后是否打开资源管理器
            gc.setFileOverride(false);  //是否覆盖
            gc.setServiceName("%sService");     //去掉Service的I前缀
            gc.setIdType(IdType.AUTO);  //设置主键的策略 (自增)
            gc.setDateType(DateType.ONLY_DATE);  //设置日期类型
            gc.setSwagger2(true);   //Swagger --待学习--
            mpg.setGlobalConfig(gc);     //将全局配置设置到自动生成对象中
    
            /**2.设置数据源
             */
            DataSourceConfig dsc = new DataSourceConfig();
            dsc.setDriverName("com.mysql.jdbc.Driver");
            dsc.setUrl("jdbc:mysql://localhost:3306/ssm");
            dsc.setUsername("root");
            dsc.setPassword("000000");
            dsc.setDbType(DbType.MYSQL);
            mpg.setDataSource(dsc);
    
            /**3.包的配置
             */
            PackageConfig pc = new PackageConfig();
            pc.setModuleName("Data");   //设置模块名(包名)
            pc.setParent("com.leon");   //设置模块的位置(生成包的位置)
            pc.setEntity("domain");     //设置实体类的名字
            pc.setMapper("mapper");     //设置存放mapper包的名字
            pc.setService("service");   //设置业务层包的名字
            pc.setController("controller");     //设置控制层包的名字
            mpg.setPackageInfo(pc);
    
            /**4.策略配置
             */
            StrategyConfig sc = new StrategyConfig();
            sc.setInclude("account");   //设置要映射的表名,可以是多张表
            sc.setNaming(NamingStrategy.underline_to_camel);    //表名:驼峰命名可以匹配下划线
            sc.setColumnNaming(NamingStrategy.underline_to_camel);  //字段名:驼峰命名可以匹配下划线
            sc.setSuperEntityClass("自己的父类实体,没有可以不写");
            sc.setEntityLombokModel(true);      //开启lombok
            //sc.setRestControllerStyle(true);    //开启链式编程
            sc.setLogicDeleteFieldName("deleted");  //设置逻辑删除字段名
            //自动填充配置
            TableFill createTime = new TableFill("create_time", FieldFill.INSERT);
            TableFill updateTime = new TableFill("update_time",FieldFill.INSERT_UPDATE);
            ArrayList<TableFill> tableFills = new ArrayList<>();    //将两个字段自动填充对象添加到List集合中
            tableFills.add(createTime);
            tableFills.add(updateTime);
            sc.setTableFillList(tableFills);    //在策略中添加包含两个自动填充策略的集合
            //乐观锁配置
            sc.setVersionFieldName("version");
            //设置controller可以使用Restful的驼峰命名方式
            sc.setRestControllerStyle(true);
            //在url中可以这样表示:localhost:3306/hello_world_1
            sc.setControllerMappingHyphenStyle(true);
            mpg.setStrategy(sc);
    
    
            mpg.execute(); //执行
        }

    执行后报错:

    导入依赖

    		<dependency>
    			<groupId>org.apache.velocity</groupId>
    			<artifactId>velocity-engine-core</artifactId>
    			<version>2.0</version>
    		</dependency>

    后执行成功

     

     

     

    案例配置信息

    server.port=8080
    spring.profiles.active=dev
    #警用模板缓存
    spring.thymeleaf.cache=false
    
    #数据库连接配置
    spring.datasource.driver-class-name=com.mysql.jdbc.Driver
    spring.datasource.username=root
    spring.datasource.password=000000
    spring.datasource.url=jdbc:mysql://localhost:3306/ssm
    
    #配置逻辑删除
    mybatis-plus.global-config.db-config.logic-delete-value=1
    mybatis-plus.global-config.db-config.logic-not-delete-value=0

    案例依赖信息

    	<properties>
    		<java.version>1.8</java.version>
    	</properties>
    
    	<dependencies>
    
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-web</artifactId>
    		</dependency>
    
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-test</artifactId>
    			<scope>test</scope>
    			<exclusions>
    				<exclusion>
    					<groupId>org.junit.vintage</groupId>
    					<artifactId>junit-vintage-engine</artifactId>
    				</exclusion>
    			</exclusions>
    		</dependency>
    
    		<dependency>
    			<groupId>org.projectlombok</groupId>
    			<artifactId>lombok</artifactId>
    			<optional>true</optional>
    		</dependency>
    
    		<dependency>
    			<groupId>com.baomidou</groupId>
    			<artifactId>mybatis-plus-boot-starter</artifactId>
    			<version>3.0.5</version>
    		</dependency>
    
    		<dependency>
    			<groupId>mysql</groupId>
    			<artifactId>mysql-connector-java</artifactId>
    			<version>5.1.6</version>
    		</dependency>
    
    		<dependency>
    			<groupId>org.apache.velocity</groupId>
    			<artifactId>velocity-engine-core</artifactId>
    			<version>2.0</version>
    		</dependency>
    
    	</dependencies>

     

    展开全文
  • // 演示例子,执行 main 方法控制台输入模块表名回车自动生成对应项目目录中 public class CodeGenerator { /** * <p> * 读取控制台内容 * </p> */ public static String scanner(String tip) { ...

    1.配置

    // 演示例子,执行 main 方法控制台输入模块表名回车自动生成对应项目目录中
    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("jobob");
            gc.setOpen(false);
            // gc.setSwagger2(true); 实体属性 Swagger2 注解
            mpg.setGlobalConfig(gc);
    
            // 数据源配置
            DataSourceConfig dsc = new DataSourceConfig();
            dsc.setUrl("jdbc:mysql://localhost:3306/ant?useUnicode=true&useSSL=false&characterEncoding=utf8");
            // dsc.setSchemaName("public");
            dsc.setDriverName("com.mysql.jdbc.Driver");
            dsc.setUsername("root");
            dsc.setPassword("密码");
            mpg.setDataSource(dsc);
    
            // 包配置
            PackageConfig pc = new PackageConfig();
            pc.setModuleName(scanner("模块名"));
            pc.setParent("com.baomidou.ant");
            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/" + pc.getModuleName()
                            + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;
                }
            });
            /*
            cfg.setFileCreate(new IFileCreate() {
                @Override
                public boolean isCreate(ConfigBuilder configBuilder, FileType fileType, String filePath) {
                    // 判断自定义文件夹是否需要创建
                    checkDir("调用默认方法创建的目录,自定义目录用");
                    if (fileType == FileType.MAPPER) {
                        // 已经生成 mapper 文件判断存在,不想重新生成返回 false
                        return !new File(filePath).exists();
                    }
                    // 允许生成模板文件
                    return true;
                }
            });
            */
            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.setSuperEntityClass("你自己的父类实体,没有就不用设置!");
            strategy.setEntityLombokModel(true);
            strategy.setRestControllerStyle(true);
            // 公共父类
            strategy.setSuperControllerClass("你自己的父类控制器,没有就不用设置!");
            // 写于父类中的公共字段
            strategy.setSuperEntityColumns("id");
            strategy.setInclude(scanner("表名,多个英文逗号分割").split(","));
            strategy.setControllerMappingHyphenStyle(true);
            strategy.setTablePrefix(pc.getModuleName() + "_");
            mpg.setStrategy(strategy);
            mpg.setTemplateEngine(new FreemarkerTemplateEngine());
            mpg.execute();
        }
    
    }
    

    2.添加依赖

    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-generator</artifactId>
        <version>3.3.2</version>
    </dependency>
    
    
    <dependency>
        <groupId>org.apache.velocity</groupId>
        <artifactId>velocity-engine-core</artifactId>
        <version>2.2</version>
    </dependency>
    
    <dependency>
        <groupId>org.freemarker</groupId>
        <artifactId>freemarker</artifactId>
        <version>2.3.30</version>
    </dependency>
    
    <dependency>
        <groupId>com.ibeetl</groupId>
        <artifactId>beetl</artifactId>
        <version>3.1.7.RELEASE</version>
    </dependency>
    
    AutoGenerator generator = new AutoGenerator();
    
    // set freemarker engine
    generator.setTemplateEngine(new FreemarkerTemplateEngine());
    
    // set beetl engine
    generator.setTemplateEngine(new BeetlTemplateEngine());
    
    // set custom engine (reference class is your custom engine class)
    generator.setTemplateEngine(new CustomTemplateEngine());
    
    // other config
    ...
    

    3.编写配置
    配置 GlobalConfig

    GlobalConfig globalConfig = new GlobalConfig();
    globalConfig.setOutputDir(System.getProperty("user.dir") + "/src/main/java");
    globalConfig.setAuthor("jobob");
    globalConfig.setOpen(false);
    

    配置 DataSourceConfig

    DataSourceConfig dataSourceConfig = new DataSourceConfig();
    dataSourceConfig.setUrl("jdbc:mysql://localhost:3306/ant?useUnicode=true&useSSL=false&characterEncoding=utf8");
    dataSourceConfig.setDriverName("com.mysql.jdbc.Driver");
    dataSourceConfig.setUsername("root");
    dataSourceConfig.setPassword("password");
    

    自定义代码模板

    //指定自定义模板路径, 位置:/resources/templates/entity2.java.ftl(或者是.vm)
    //注意不要带上.ftl(或者是.vm), 会根据使用的模板引擎自动识别
    TemplateConfig templateConfig = new TemplateConfig()
        .setEntity("templates/entity2.java");
    
    AutoGenerator mpg = new AutoGenerator();
    //配置自定义模板
    mpg.setTemplate(templateConfig);
    

    自定义属性注入

    InjectionConfig injectionConfig = new InjectionConfig() {
        //自定义属性注入:abc
        //在.ftl(或者是.vm)模板中,通过${cfg.abc}获取属性
        @Override
        public void initMap() {
            Map<String, Object> map = new HashMap<>();
            map.put("abc", this.getConfig().getGlobalConfig().getAuthor() + "-mp");
            this.setMap(map);
        }
    };
    AutoGenerator mpg = new AutoGenerator();
    //配置自定义属性注入
    mpg.setCfg(injectionConfig);
    
    entity2.java.ftl
    自定义属性注入abc=${cfg.abc}
    
    entity2.java.vm
    自定义属性注入abc=$!{cfg.abc}
    
    new DataSourceConfig().setDbQuery(new MySqlQuery() {
    
        /**
         * 重写父类预留查询自定义字段<br>
         * 这里查询的 SQL 对应父类 tableFieldsSql 的查询字段,默认不能满足你的需求请重写它<br>
         * 模板中调用:  table.fields 获取所有字段信息,
         * 然后循环字段获取 field.customMap 从 MAP 中获取注入字段如下  NULL 或者 PRIVILEGES
         */
        @Override
        public String[] fieldCustom() {
            return new String[]{"NULL", "PRIVILEGES"};
        }
    })
    

    参考网站:MyBatisPlus官网

    展开全文
  • 使用MybatisPlus自动生成代码工具

    千次阅读 2020-02-13 23:56:04
    项目环境: 开发环境:IntelliJ IDEA 2019.3.1 ,JDK1.8 ,MySQL: 5.6.47 ... AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller...
  • 自动生成mapper接口层,service层,控制器层的crud,包括分页的操作,以及对应的qo高查类
  • 这个是我生成代码时设置的表名 <p style="text-align:center"><img alt="" height="109" src="https://img-ask.csdnimg.cn/upload/1615823454584.png" width="757" /></p> 运行后报错是...
  • MybatisPlus自动生成代码详解 创建springboot项目 pom.xml <dependency> <groupId>io.swagger</groupId> <artifactId>swagger-annotations</artifactId> <version>1.5.18<...
  • 引入Mybatis-plus-generator代码自动生成工具 1、Mybatis-plus-generator介绍 AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等...
  • Created by NXS * 2020/10/23 14:31 */ // 执行 main 方法控制台输入模块表名回车自动生成对应项目目录中 public class CodeGenerator { public static void main(String[] args) { // 需要构建一个 代码自动生成器 ...
  • 自动生成代码 报错 解决办法:把自动xml文件中自动生成的二级缓存注释掉
  • 没有在pom文件中导入jar包 <!--配置ApiModel在实体类中不生效--> <dependency> <groupId>com.spring4all</groupId> <artifactId>spring-boot-starter-swagger<...1.5.1.REL
  • 使用mybatis-plus代码生成器自动生成实体类,service, mapper, xml, 内含单表的增删改查和丰富的条件构造器
  • /** * * 测试生成代码 * * * @author K神 * @date 2017/12/18 */ public class GeneratorServiceEntity { @Test public void generateCode() { String packageName = "com.SpringBoot.*"; boolean ...
  • 用了一段时间的springboot,想着百度一下自动生成代码的...1 自动生成代码方式:com.baomidou.mybatisplus ** mvn配置: <!--mybatis-plus--> <dependency> <groupId>com.baomidou</gro...
  • package ... import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException; import com.baomidou.mybatisplus.core.toolkit.StringUtils; import com.baomidou.mybatisplus.generator.A...
  • **介绍:**mybatis自动生成策略 可以自动帮你生成service、mapper、pojo层 操作步骤: 1.导入依赖 <!--mybatisPlus包--> <dependency> <groupId>com.baomidou</groupId> <artifactId...
  • 就让我当一条懒到家的咸鱼吧但是就是这个生活态度,也让我深刻体会到...“一键生成”之Mybatis-Plus自动生成代码通过Mybatis-Plus强大的自动代码生成功能我们可以让项目自动生成一些通用的类。如controller,service...
  • mybatisplus 自动生成代码 application.yml配置 # DataSource Config spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/stu?useUnicode=true&useSSL=...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 7,232
精华内容 2,892
关键字:

mybatisplus自动生成代码