首页 > 其他分享 >MyBatis plus 代码生成器

MyBatis plus 代码生成器

时间:2023-02-21 00:01:22浏览次数:37  
标签:代码生成 autoGenerator strategyConfig plus dataSource 设置 MyBatis globalConfig com

  1. 导入依赖

    <!--代码生成器-->
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-generator</artifactId>
        <version>3.4.1</version>
    </dependency>
    
    <!--velocity模板引擎-->
    <dependency>
        <groupId>org.apache.velocity</groupId>
        <artifactId>velocity-engine-core</artifactId>
        <version>2.3</version>
    </dependency>
    
  2. 写一个类 Generator ,名字叫什么都行,写在哪里也都可以,在这个类里面写main方法,运行main方法即可生成代码,内容如下:

    public static void main(String[] args) {
            //获取代码生成器对象
            AutoGenerator autoGenerator = new AutoGenerator();
    
            //设置数据库相关配置
            DataSourceConfig dataSource = new DataSourceConfig();
            dataSource.setDriverName("com.mysql.cj.jdbc.Driver");
            dataSource.setUrl("jdbc:mysql://localhost:3306/db?serverTimezone=UTC");
            dataSource.setUsername("root");
            dataSource.setPassword("1234");
            autoGenerator.setDataSource(dataSource);
    
            //设置全局配置
            GlobalConfig globalConfig = new GlobalConfig();
            globalConfig.setOutputDir(System.getProperty("user.dir") + "/src/main/java");//设置代码输出位置,否则默认输出到D://目录下
            globalConfig.setOpen(false);//设置生成完毕后是否打开生成代码的目录,一般选择false,不需要打开目录
            globalConfig.setAuthor("tuuli");//作者名字,会在注释中添加作者名字
            globalConfig.setFileOverride(true);//是否覆盖原始生成的文件,选择true后,生成时若原来已有相同文件会自动覆盖,谨慎操作
            globalConfig.setMapperName("%sDao");//设置数据层接口名,%s为占位符,指代模块名称,默认为"%sMapper"
            globalConfig.setIdType(IdType.AUTO);//设置id生成策略
            autoGenerator.setGlobalConfig(globalConfig);
    
            //设置包名配置
            PackageConfig packageConfig = new PackageConfig();
            packageConfig.setParent("com.tuuli");//设置生成的包名,默认为"com.baomidou"
            packageConfig.setEntity("domain");//设置实体类包名,默认为entity
            packageConfig.setMapper("dao");//设置数据层包名,默认为mapper
            autoGenerator.setPackageInfo(packageConfig);
    
            //策略设置
            StrategyConfig strategyConfig = new StrategyConfig();
            strategyConfig.setInclude("tb_course");//设置参与生成的表名,可填一个或多个
            strategyConfig.setTablePrefix("tb_");//设置数据库表名的前缀名称,设置后会省略该前缀
            strategyConfig.setRestControllerStyle(false);//设置是否启用Rest风格
            //strategyConfig.setLogicDeleteFieldName("deleted");//设置逻辑删除字段名,没有就不填
            strategyConfig.setEntityLombokModel(true);//设置是否启用Lombok
            autoGenerator.setStrategy(strategyConfig);
    
            //执行生成操作
            autoGenerator.execute();
        }
    
  3. 测试

    • 新建一个springboot项目,导入相关依赖坐标,初始时目录结构如下:

image

  • 新建数据库,数据名db3,新建了两个表,分别为tb_user、tb_course,表结构如下:

    tb_user

    image

    tb_course

    image

    表中内容均为空。

  • 生成代码,此处代码生成器的完整代码的如下:

    package com.tuuli;
    
    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;
    
    /**
     * @author tuuli
     * @time Created in 2023/2/20 23:21
     * @description
     */
    public class Generator {
        public static void main(String[] args) {
            //获取代码生成器对象
            AutoGenerator autoGenerator = new AutoGenerator();
    
            //设置数据库相关配置
            DataSourceConfig dataSource = new DataSourceConfig();
            dataSource.setDriverName("com.mysql.cj.jdbc.Driver");
            dataSource.setUrl("jdbc:mysql://localhost:3306/db3?serverTimezone=UTC");
            dataSource.setUsername("root");
            dataSource.setPassword("1234");
            autoGenerator.setDataSource(dataSource);
    
            //设置全局配置
            GlobalConfig globalConfig = new GlobalConfig();
            globalConfig.setOutputDir(System.getProperty("user.dir") + "/src/main/java");//设置代码输出位置,否则默认输出到D://目录下
            globalConfig.setOpen(false);//设置生成完毕后是否打开生成代码的目录,一般选择false,不需要打开目录
            globalConfig.setAuthor("tuuli");//作者名字,会在注释中添加作者名字
            globalConfig.setFileOverride(true);//是否覆盖原始生成的文件,选择true后,生成时若原来已有相同文件会自动覆盖,谨慎操作
            globalConfig.setMapperName("%sDao");//设置数据层接口名,%s为占位符,指代模块名称,默认为"%sMapper"
            globalConfig.setIdType(IdType.AUTO);//设置id生成策略
            autoGenerator.setGlobalConfig(globalConfig);
    
            //设置包名配置
            PackageConfig packageConfig = new PackageConfig();
            packageConfig.setParent("com.tuuli");//设置生成的包名,默认为"com.baomidou"
            packageConfig.setEntity("domain");//设置实体类包名,默认为entity
            packageConfig.setMapper("dao");//设置数据层包名,默认为mapper
            autoGenerator.setPackageInfo(packageConfig);
    
            //策略设置
            StrategyConfig strategyConfig = new StrategyConfig();
            strategyConfig.setInclude("tb_course", "tb_user");//设置参与生成的表名,可填一个或多个
            strategyConfig.setTablePrefix("tb_");//设置数据库表名的前缀名称,设置后会省略该前缀
            strategyConfig.setRestControllerStyle(false);//设置是否启用Rest风格
            //strategyConfig.setLogicDeleteFieldName("deleted");//设置逻辑删除字段名,没有就不填
            strategyConfig.setEntityLombokModel(true);//设置是否启用Lombok
            autoGenerator.setStrategy(strategyConfig);
    
            //执行生成操作
            autoGenerator.execute();
        }
    }
    
    
  • 运行成功,目录内容已发生改变,已生成相关代码

    image

controller层代码:

image

dao层代码(请手动添加@Mapper注解,否则后面会出错):

image

domain层代码:

image

mapper.xml

image

service接口:

image

service实现类:

image

标签:代码生成,autoGenerator,strategyConfig,plus,dataSource,设置,MyBatis,globalConfig,com
From: https://www.cnblogs.com/tuuli/p/17139471.html

相关文章

  • SpringBoot04 - 整合MyBatis
    整合MyBatis​ 整合完JUnit下面再来说一下整合MyBatis,这个技术是大部分公司都要使用的技术,务必掌握。如果对Spring整合MyBatis不熟悉的小伙伴好好复习一下,下面列举出原始......
  • MyBatis-RedisCache源码分析
    回顾在前面,我们通过redis​集成了MyBatis​的二级缓存,440.MyBatis的二级缓存整合redis,接下来,我们来分析一下RedisCache​的源码。源码分析RedisCache主要是通过......
  • mybatis
    mybatis3增加注解@SelectProvidermybatis3中增加了使用注解来配置Mapper的新特性,其中@Provider的使用方式较为复杂。@provide主要分为四种:@InsertProvider@DeletePro......
  • MyBatisPlus(springBoot版)-尚硅谷
    Pom.xml<?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"......
  • DateTimePicker 日期时间选择器 + mybatis-plus 传参后端查询 传值自定义list,后端再
    前端<el-form-itemlabel="创建时间"prop="extendate"><el-date-pickerv-model="queryParams.extendate"......
  • 五、MyBatis的多表操作
    一对一查询一对一查询的模型用户表和订单表的关系为,一个用户有多个订单,一个订单只从属于一个用户一对一查询的需求:查询一个订单,与此同时查询出该订单所属的用户一对一......
  • mybatis 基本使用
    本文为笔者参考官方文档的简单学习笔记,更详细和权威信息请参考官方文档:MyBatis中文网环境配置springboot框架下参考:SpringBoot整合MyBatis-临安剑客-博客园(......
  • 若依框架 -------- vue3+element-plus(四)
    后端管理系统,前后端分离的框架若依管理后台,来看下vue3+element-plus版本。实现一个页面定义api请求gatewayPath分布式网关定义importrequestfrom'@/utils/request'impor......
  • 若依框架 -------- vue3+element-plus(三)
    后端管理系统,前后端分离的框架若依管理后台,来看下vue3+element-plus版本。静态文本assetsassets静态img、svg、stylemain.js ​​import'@/assets/styles/index.scss'/......
  • 若依框架 -------- vue3+element-plus(二)
    后端管理系统,前后端分离的框架若依管理后台,来看下vue3+element-plus版本。API后台接口请求user.js//查询用户列表exportfunctionlistUser(query){returnrequest({......