Mybatis-plus逆向工程使用方法

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 本文讲解Mybatis-plus逆向工程使用方法。

一、Mybatis-plus逆向工程使用方法



1、 引入jar包


1.1、jar包


<dependencies>
        <!--web 依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--mysql 依赖-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <!--mybatis-plus 依赖-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.3.1.tmp</version>
        </dependency>
        <!--mybatis-plus 代码生成器依赖-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.3.1.tmp</version>
        </dependency>
        <!--freemarker 依赖-->
        <dependency>
            <groupId>org.freemarker</groupId>
            <artifactId>freemarker</artifactId>
        </dependency>
    </dependencies>


2、编写代码


2.1、代码


package com.xiaoqi.generator;
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.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.NamingStrategy;
import java.util.Scanner;
/**
 * @author DaiZhiZhou
 * @file MP-Spring
 * @create 2020-08-06 9:11
 */
public class CodeGenerator {
  /**
   * <p>
   * 读取控制台内容
   * </p>
   */
  public static String scanner(String tip) {
    Scanner scanner = new Scanner(System.in);
    StringBuilder help = new StringBuilder();
    help.append("请输入").append(tip).append(":");
    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 mybatisPlusCodeGenerator = new AutoGenerator();
    // 全局配置
    GlobalConfig gc = new GlobalConfig();
    // 先得到当前工程目录
    String projectPath = System.getProperty("user.dir");
    // 是maven项目的结构,就是工程目录 + /src/main/java
    gc.setOutputDir(projectPath + "/yeb-server/src/main/java/com/xiaoqi/server");
    //gc.setOutputDir("D:\\workspace-sts\\0520adv\\02_mp_springboot/src/main/java");
    // 设置生成文件的作者信息
    gc.setAuthor("xiaoqi");
    //当代码生成完成之后是否打开代码所在的文件夹
    gc.setOpen(false);
    //xml开启BaseResultMap
    gc.setBaseResultMap(true);
    //xml开启BaseColumnList
    gc.setBaseColumnList(true);
    //实体属性 Swagger2 注解
     gc.setSwagger2(true);
    //gc.setServiceName("%sService");
    // 将上述的全局配置注入
    mybatisPlusCodeGenerator.setGlobalConfig(gc);
    // 数据源配置
    DataSourceConfig dataSourceConfiguration = new DataSourceConfig();
    dataSourceConfiguration.setUrl("jdbc:mysql://localhost:3306/yeb?useUnicode=true&useSSL=false&characterEncoding=utf8&serverTimezone=UTC");
    // dataSourceConfiguration.setSchemaName("public");
    dataSourceConfiguration.setDriverName("com.mysql.cj.jdbc.Driver");
    dataSourceConfiguration.setUsername("root");
    dataSourceConfiguration.setPassword("root");
    mybatisPlusCodeGenerator.setDataSource(dataSourceConfiguration);
    // 包配置
    PackageConfig pc = new PackageConfig();
    // 设置父级包名
   pc.setParent("");//controller entity service service.impl
  //  pc.setModuleName(scanner("模块名"));
    //pc.setModuleName("sys");
    // 实体类名称
    pc.setEntity("pojo");
    // mapper包名称
    pc.setMapper("mapper");
    // mapper对应的映射器xml
    pc.setXml("mapper.xml");
    // 业务包层名称
    pc.setService("service");
    // 业务接口的实现类包
    pc.setServiceImpl("service.impl");
    // 控制器包名称
    pc.setController("controller");
    // 装填包信息对象
    mybatisPlusCodeGenerator.setPackageInfo(pc);
    // 如果模板引擎是 freemarker
    String templatePath = "/templates/mapper.xml.ftl";
    // 策略配置
    StrategyConfig strategy = new StrategyConfig();
    //设置字段和表名的是否把下划线完成驼峰命名规则
    strategy.setNaming(NamingStrategy.underline_to_camel);
    strategy.setColumnNaming(NamingStrategy.no_change);
    //设置生成的实体类继承的父类
    //strategy.setSuperEntityClass("com.sxt.BaseEntity");
    //是否启动lombok
    strategy.setEntityLombokModel(true);
    //是否生成resetController
    strategy.setRestControllerStyle(true);
    // 公共父类
    //strategy.setSuperControllerClass("com.sxt.BaseController");
    // 写于父类中的公共字段
    //strategy.setSuperEntityColumns("person_id","person_name");
    //要设置生成哪些表 如果不设置就是生成所有的表
    //strategy.setInclude(scanner("表名,多个英文逗号分割").split(","));
    strategy.setControllerMappingHyphenStyle(true);
    //strategy.setTablePrefix(pc.getModuleName() + "_");
    strategy.setTablePrefix("t_");
    mybatisPlusCodeGenerator.setStrategy(strategy);
    mybatisPlusCodeGenerator.execute();
  }
}


3、运行程序


3.1、输入表名


运行程序后会让你输入表名称,我们输入数据库中的表名称,多个表中间用逗号分隔。


4、Mybatis-plus逆向工程和Mybatis逆向工程的区别


4.1、区别


Mybatis逆向工程生成的文件没有controller和service层,而Mybatis-plus逆向工程生成的文件包含controller和service层。


5、官网


5.1、官网


官网地址:https://baomidou.com/


在官网中我们可以看到最新的逆向工程生成方法。


13.png


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8月前
|
XML Java 数据库连接
mybatis-plus逆向工程详解
mybatis-plus逆向工程详解
417 0
|
XML Java 数据库连接
Mybatis使用generator逆向工程生成器生成entity、mapper、.xml模版类
今天将表建好了,但是一个一个的建实体类、Mapper接口、Mapper.xml文件就十分的麻烦,所以我就想到了MyBatis逆向,今天就操作一把!这里我们采用maven来进行操作。
333 0
|
2月前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
2月前
|
Java 数据库连接 数据库
spring和Mybatis的逆向工程
通过本文的介绍,我们了解了如何使用Spring和MyBatis进行逆向工程,包括环境配置、MyBatis Generator配置、Spring和MyBatis整合以及业务逻辑的编写。逆向工程极大地提高了开发效率,减少了重复劳动,保证了代码的一致性和可维护性。希望这篇文章能帮助你在项目中高效地使用Spring和MyBatis。
42 1
|
3月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
168 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
8月前
|
Java 数据库连接 数据库
Mybatis逆向工程笔记小结
Mybatis逆向工程笔记小结
|
7月前
|
SQL 缓存 Java
Java框架之MyBatis 07-动态SQL-缓存机制-逆向工程-分页插件
Java框架之MyBatis 07-动态SQL-缓存机制-逆向工程-分页插件
|
8月前
|
XML Java 数据库连接
Mybatis逆向工程的2种方法,一键高效快速生成Pojo、Mapper、XML,摆脱大量重复开发
【5月更文挑战第10天】Mybatis逆向工程的2种方法,一键高效快速生成Pojo、Mapper、XML,摆脱大量重复开发
91 6
|
8月前
|
数据库
Springboot+mybatis-plus逆向工程生成代码器
Springboot+mybatis-plus逆向工程生成代码器
|
8月前
|
SQL Java 数据库连接
MyBatis之逆向工程
【1月更文挑战第4天】 正向工程:先创建Java实体类,由框架负责根据实体类生成数据库表。Hibernate是支持正向工程的 逆向工程:先创建数据库表,由框架负责根据数据库表,反向生成如下资源: Java实体类 Mapper接口 Mapper映射文件
69 2