Mybatis-plus 自动生成代码

Mybatis-Plus 生成代码的方式分两种,通过3.5.1版本区分新和旧,这里以3.5.3.1版本为例,使用新的代码生成器方式生成。

参考官网:代码生成器(新)

具体步骤如下:
1、导入依赖

 <!-- https://mvnrepository.com/artifact/com.baomidou/mybatis-plus-boot-starter -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.3.1</version>
        </dependency>
        <!-- 代码生成器 -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.5.3.1</version>
        </dependency>
        <!-- mysql驱动 -->
        <dependency>
            <groupId>com.mysql</groupId>
            <artifactId>mysql-connector-j</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>

2、创建生成器类
创建代码生成器类


import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.config.OutputFile;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import com.baomidou.mybatisplus.generator.fill.Column;
import org.apache.ibatis.annotations.Mapper;

import java.util.ArrayList;
import java.util.Collections;

/**
 * mybatis-plus 代码生成器
 *
 * @author Feiz.Zheng
 */
public class GeneratorCode {
    public static void main(String[] args) {


        String projectPath = System.getProperty("user.dir");   // 获取项目路径


        String path = projectPath + "\\src\\main\\java";
        String url = "jdbc:mysql://127.0.0.1:3306/xxxx?useSSL=false&useUnicode=true&serverTimeZone=GMT%2b8"; //数据库url
        String username = "xxx";   //用户名
        String password = "xxx";   // 密码
        ArrayList<String> tables = new ArrayList<>();   // 需要生成代码的表有哪些
        tables.add("integration_user");
        FastAutoGenerator.create(url, username, password)
                .globalConfig(builder -> {
                    builder.author("mntalk")    // 设置author
                            .enableSwagger()    // 添加Swagger注解
                            .fileOverride()
                            .outputDir(path);  //设置路径
                })
                .packageConfig(builder -> {
                    builder.parent("com.xxx.integration")  // 包路径,改成自己的
                            .entity("entity")               // 实体包名
                            .service("service")             // service包名
                            .serviceImpl("service.impl")    // service实现类包名
                            .xml("mapper")                  // dao层包名
                            .controller("controller")       // controller包名
                            .pathInfo(Collections.singletonMap(OutputFile.xml, projectPath + "\\src\\main\\resources\\mapper"));    // xml映射文件包名
                })
                .strategyConfig(builder -> {
                    builder.addInclude(tables)
                            .addTablePrefix("integration_")     // 表前缀

                            .serviceBuilder()               // 构建service
                            .formatServiceFileName("%sService")     // service命名规则
                            .formatServiceImplFileName("%sServiceImpl") //service实现类命名规则

                            .controllerBuilder()        // 构建controller
                            .formatFileName("%sController") // controller命名规则
                            .enableRestStyle() //驼峰命名

                            .entityBuilder()    //构建实体类
                            .enableChainModel()
                            .idType(IdType.AUTO)    //id类型
                            .enableLombok()         //lombok
                            .naming(NamingStrategy.underline_to_camel)  // 数据库下划线转为驼峰式命名
                            .logicDeleteColumnName("deleted")       // 逻辑删除字段
                            .versionColumnName("version")           // 乐观锁
                            .addTableFills(new Column("gmt_create", FieldFill.INSERT))      // 新增时填充
                            .addTableFills(new Column("gmt_modified", FieldFill.INSERT_UPDATE)) // 新增或修改时填充
                            .enableTableFieldAnnotation()

                            .mapperBuilder()    // 构建dao层
                            .enableBaseResultMap() // 通用map
                            .superClass(BaseMapper.class)   // 继承 BaseMapper
                            .formatMapperFileName("%sMapper")   // dao层命名规则
                            .formatXmlFileName("%sMapper")  // xml映射文件命名规则
                            .mapperAnnotation(Mapper.class); // dao层添加@Mapper注解
                })
                .templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker模板引擎
                .execute();
    }
}

代码都加了注释的,很容易理解。数据库地址、用户名和密码换成自己的就行,有哪些表需要生成代码。添加到 tables 容器里面就行。

运行代码之后,项目结构如下所示:

在这里插入图片描述

这样就行了,之后其他配置请参考官网或者评论留言。

求一键三连:点赞、分享、收藏
点赞对我真的非常重要!在线求赞,加个关注我会非常感激!@小郑聊编程

  • 12
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如何使用? 很高兴为您解答这个问题。为了使用MyBatis-Plus自动生成代码模板Controller,您需要遵循以下步骤: 1. 安装MyBatis-Plus插件。您可以在Maven中添加以下代码来添加MyBatis-Plus依赖项: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.1</version> </dependency> ``` 2. 根据您的需要配置MyBatis-Plus。您可以在application.properties文件中添加以下配置: ```properties # 数据库连接 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://your-database-url:3306/your-database-name?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=UTC spring.datasource.username=your-database-username spring.datasource.password=your-database-password # MyBatis-Plus配置 mybatis-plus.mapper-locations=classpath:mapper/*.xml mybatis-plus.type-aliases-package=com.example.demo.entity ``` 3. 在您的实体类中添加需要映射的数据库表。对于每个表,需要创建一个Java类,用于映射表中的数据。您可以使用MyBatis-Plus提供的注解来配置主键和字段的映射: ```java @Data @TableName("user") // 表名 public class User { @TableId(value = "id", type = IdType.AUTO) // 主键 private Long id; @TableField("name") // 字段 private String name; // 省略其他字段 } ``` 4. 使用MyBatis-Plus代码生成器生成代码MyBatis-Plus提供了一个代码生成器,该生成器可以根据您的实体类和数据库表自动生成代码。您可以使用以下命令启动代码生成器: ```java import com.baomidou.mybatisplus.generator.AutoGenerator; public class CodeGenerator { public static void main(String[] args) { AutoGenerator mpg = new AutoGenerator(); // 定义包名和文件路径 // ... // 配置数据源 // ... // 配置生成策略 // ... // 配置模板 // ... mpg.execute(); } } ``` 5. 完成后,您将在指定的文件夹中看到生成的代码,包括实体类、Mapper接口、XML文件和Service类。 希望这能帮到您!如果您有任何其他问题,请随时问我。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值