【MyBatis-Plus】 代码生成器使用指南——快速上手最好用的代码生成器!


在这里插入图片描述

1. 简介

MyBatis-Plus 是一个 MyBatis 的增强工具,简化了 MyBatis 的开发过程。作为一个 ORM 框架,MyBatis-Plus 提供了很多便捷的功能,其中之一就是代码生成器。代码生成器可以根据数据库表结构自动生成相应的实体类、Mapper 接口、Service 接口及其实现类等,大大提高了开发效率,减少了重复劳动。

本文将详细介绍如何使用 MyBatis-Plus 的代码生成器生成 Java 代码,以便快速开始项目开发。

2. 环境准备

在开始之前,请确保已经安装并配置好了以下环境:

  • JDK 1.8 或以上版本
  • MySQL 数据库
  • IntelliJ IDEA 或 Eclipse 等 IDE
  • Maven 或 Gradle 构建工具

3. 项目结构

首先,我们需要创建一个标准的 Maven 项目,目录结构如下:

mybatis-plus-generator
├── src
│   ├── main
│   │   ├── java
│   │   └── resources
├── pom.xml
└── README.md

4. 引入依赖

pom.xml 文件中引入 MyBatis-Plus 和代码生成器的依赖:

<dependencies>
    <!-- MyBatis-Plus 依赖 -->
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-boot-starter</artifactId>
        <version>3.4.1</version>
    </dependency>
    
    <!-- MyBatis-Plus 代码生成器依赖 -->
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-generator</artifactId>
        <version>3.4.1</version>
    </dependency>

    <!-- 数据库连接池 -->
    <dependency>
        <groupId>com.zaxxer</groupId>
        <artifactId>HikariCP</artifactId>
        <version>3.4.5</version>
    </dependency>

    <!-- MySQL 驱动 -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.21</version>
    </dependency>

    <!-- 模板引擎 -->
    <dependency>
        <groupId>org.freemarker</groupId>
        <artifactId>freemarker</artifactId>
        <version>2.3.30</version>
    </dependency>
</dependencies>

5. 编写代码生成器配置类

src/main/java 目录下创建一个名为 GeneratorCodeConfig 的类,代码如下:

package com.stu.test;

import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.*;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;

import java.util.Scanner;

/**
 * 自动生成mybatisplus的相关代码
 */
public class GeneratorCodeConfig {

    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"); // D:\123\ZiRu

        // 代码生成的地址: D:/Stu/src/main/java
        System.out.println(projectPath + "/src/main/java");

        gc.setOutputDir(projectPath + "/src/main/java");
        gc.setAuthor("bruce"); //作者信息
        gc.setOpen(false);

        //实体属性 Swagger2 注解
        gc.setSwagger2(true);
        mpg.setGlobalConfig(gc);

        // 配置自己数据源-----------数据源配置
        DataSourceConfig dsc = new DataSourceConfig();
        dsc.setUrl("jdbc:mysql://127.0.0.1:3306/stu?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowPublicKeyRetrieval=true");
        dsc.setDriverName("com.mysql.cj.jdbc.Driver");
        dsc.setUsername("root");
        dsc.setPassword("123456");
        mpg.setDataSource(dsc);

        // 配置自己包配置
        PackageConfig pc = new PackageConfig();
        pc.setParent("com.ziru");
        pc.setEntity("bean");
        pc.setMapper("mapper");
        pc.setService("service");
        pc.setServiceImpl("service.impl");
        mpg.setPackageInfo(pc);


        // 配置模板
        TemplateConfig templateConfig = new TemplateConfig();

        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(","));
        strategy.setControllerMappingHyphenStyle(true);
        //数据库表的前缀
        //strategy.setTablePrefix("tb_");
        mpg.setStrategy(strategy);
        mpg.setTemplateEngine(new FreemarkerTemplateEngine());
        mpg.execute();
    }
}

6. 配置解释

以下是主要配置项的详细解释:

6.1 全局配置

GlobalConfig 类用于配置全局参数:

  • setOutputDir:设置代码生成的输出目录。
  • setAuthor:设置作者信息。
  • setOpen:生成后是否打开输出目录。
  • setSwagger2:是否生成 Swagger2 注解。
6.2 数据源配置

DataSourceConfig 类用于配置数据源参数:

  • setUrl:数据库连接 URL。
  • setDriverName:数据库驱动名称。
  • setUsername:数据库用户名。
  • setPassword:数据库密码。
6.3 包配置

PackageConfig 类用于配置包名:

  • setParent:父包名。
  • setEntity:实体类包名。
  • setMapper:Mapper 接口包名。
  • setService:Service 接口包名。
  • setServiceImpl:Service 实现类包名。
6.4 模板配置

TemplateConfig 类用于配置模板路径:

  • setXml:设置 XML 文件模板路径。此处设置为 null,表示不生成 XML 文件。
6.5 策略配置

StrategyConfig 类用于配置生成策略:

  • setNaming:数据库表映射到实体的命名策略。
  • setColumnNaming:数据库表字段映射到实体的命名策略。
  • setInclude:需要生成的表名,多个表名用逗号分割。
  • setControllerMappingHyphenStyle:是否开启驼峰转连字符。

7. 运行代码生成器

运行 GeneratorCodeConfig 类的 main 方法,根据提示输入表名,代码生成器将自动生成与表对应的实体类、Mapper 接口、Service 接口及其实现类等文件。

8. 生成的代码结构

生成的代码结构如下:

src/main/java
└── com
    └── ziru
        ├── bean
        │   └── <Entity>.java
        ├── mapper
        │   └── <Entity>Mapper.java
        ├── service
        │   └── <Entity>Service.java
        └── service
            └── impl
                └── <Entity>ServiceImpl.java

9. 总结

通过 MyBatis-Plus 的代码生成器,开发者可以快速生成基础的 CRUD 代码,大大提高了开发效率,减少了重复劳动。本文详细介绍了如何配置和使用 MyBatis-Plus 的代码生成器,帮助开发者更好地理解和应用这一工具。更多详细信息和高级配置可以参考 MyBatis-Plus 官方文档

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值