代码编织梦想

SpringCloud 大型系列课程正在制作中,欢迎大家关注与提意见。
程序员每天的CV 与 板砖,也要知其所以然,本系列课程可以帮助初学者学习 SpringBooot 项目开发 与 SpringCloud 微服务系列项目开发

1 项目准备

创建SpringBoot基础项目
SpringBoot项目集成mybatis
SpringBoot 集成 Druid 数据源【SpringBoot系列3】
SpringBoot MyBatis 实现分页查询数据【SpringBoot系列4】
SpringBoot MyBatis-Plus 集成 【SpringBoot系列5】

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

MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码。

MyBatis-Plus 从 3.0.3 之后移除了代码生成器与模板引擎的默认依赖,需要手动添加相关依赖:
在 pom.xml 文件中添加 AutoGenerator 的依赖。

  <!-- https://mvnrepository.com/artifact/com.baomidou/mybatis-plus-generator -->
  <dependency>
      <groupId>com.baomidou</groupId>
      <artifactId>mybatis-plus-generator</artifactId>
      <version>3.5.3.1</version>
  </dependency>

添加模板引擎依赖,MyBatis-Plus 支持 Velocity(默认)、Freemarker、Beetl,这里使用Freemarker引擎。

<!-- https://mvnrepository.com/artifact/org.freemarker/freemarker -->
 <dependency>
     <groupId>org.freemarker</groupId>
     <artifactId>freemarker</artifactId>
     <version>2.3.32</version>
 </dependency>

2 创建用户分类 表

CREATE TABLE `user-category` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `category_name` varchar(255) DEFAULT NULL,
  `create_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='用户分类表';

然后定义代码生成器 CodeGenerator

  • com.biglead.demo.code 为项目包名

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.config.TemplateType;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;

/**
 * 代码生成器
 *
 * @author: 早起的年轻人
 * @since: 2023/3/6 15:28
 */
public class CodeGenerator {
    public static void main(String[] args) {

        // 数据源配置
        FastAutoGenerator.create("jdbc:mysql://mysql:3306/spring_boot?useUnicode=true&zeroDateTimeBehavior=convertToNull&autoReconnect=true&characterEncoding=utf-8&useSSL=false",
                        "testadmin", "qwert.12345")
                .globalConfig(builder -> {
                    builder.author("早起的年轻人")        // 设置作者
                            .enableSwagger()        // 开启 swagger 模式 默认值:false
                            .disableOpenDir()       // 禁止打开输出目录 默认值:true
                            .commentDate("yyyy-MM-dd") // 注释日期
                            .dateType(DateType.ONLY_DATE)   //定义生成的实体类中日期类型 DateType.ONLY_DATE 默认值: DateType.TIME_PACK
                            .outputDir(System.getProperty("user.dir") + "/src/main/java")// 指定输出目录
                    ;
                })
                .packageConfig(builder -> {
                    builder.parent("com.biglead.demo.code")
                            .moduleName("auto")
                            .entity("po")
                            .service("service")
                            .serviceImpl("service.impl")
                            .mapper("mapper")
                            .xml("mapper.xml")
                            .controller("controller");
                }).strategyConfig(builder -> {
                    builder.addInclude("user_category") // 设置需要生成的表名
                            .addTablePrefix("t_", "c_") // 设置过滤表前缀
                            .mapperBuilder()
                            .superClass(BaseMapper.class)
                            .enableBaseResultMap()
                            .enableBaseColumnList()
                            .formatMapperFileName("%sMapper")
                            .formatXmlFileName("%sXml")
                            .enableFileOverride();//删除已存在的
                }).templateConfig(builder -> {
                    builder.disable(TemplateType.ENTITY)
                            .entity("/templates/entity.java")
                            .service("/templates/service.java")
                            .serviceImpl("/templates/serviceImpl.java")
                            .mapper("/templates/mapper.java")
                            .controller("/templates/controller.java")
                            .xml("/templates/mapper.xml")
                    ;
                })
                .injectionConfig(builder -> {

                })
                .templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
                .execute();

    }
}

在这里插入图片描述
然后把这些类移动到你需要的目录下即可

项目源码在这里 :https://gitee.com/android.long/spring-boot-study/tree/master/biglead-api-05-mybatis-plus
有兴趣可以关注一下公众号:biglead

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/zl18603543572/article/details/129538743

springboot学习05--使用mybatis-plus代码生成器_leoxyk的博客-爱代码爱编程

AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码

springboot mybatis-plus 配置 yml 、druid 配置 yml 、mybatis-plus 代码生成-爱代码爱编程

大家好,我是烤鸭: 今天分享一下 springboot mybatis-plus 和 druid 的yml 配置文件。   pom <dependency>           <groupId>org.springframework.boot</groupId>           <artifa

SpringBoot使用Mybatis-Plus Generator生成代码-爱代码爱编程

概述 MyBatis-Plus(简称MP)是一个 Mybatis 的增强工具,在 Mybatis 的基础上只做增强不做改变,为简化开发、提高效率而生。 AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controll

SpringBoot集成Mybatis-Plus最新代码自动生成器v3.5.1-爱代码爱编程

目录 一、概述二、导入依赖三、运行类(放在测试类中即可)四、配置说明1. 数据库配置(DataSourceConfig)2. 全局配置(GlobalConfig)3. 包配置(PackageConfig)4. 模板配置(TemplateConfig)5. 注入配置(InjectionConfig)6. 策略配置(StrategyConfig)6.1

mybatis——》mybatis-plus-generator代码生成器_小仙。的博客-爱代码爱编程

推荐链接:     总结——》【Java】     总结——》【Mysql】     总结——》【Spring】     总结——》【SpringBoot】     总结——》【MyBatis、MyBatis-Plus

springboot集成mybatis-plus + mybatis-plus代码生成器+swagger接口文档_骑猪兜风~的博客-爱代码爱编程

目录 创建一个新的spring web项目 配置.pom文件,引入jar依赖包 MyBatis-Plus依赖包 MyBatis-Plus代码生成器依赖包 删除.properties文件,或者将其修改为.yaml文件,配置.yaml文件 主程序入口进行注解配置 创建CodeGenerator代码生成器 配置Swagger 添加Swagger

springboot mybatis-plus 3.5.1代码生成器配置_北方的文先生的博客-爱代码爱编程

一. 引入坐标 <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.5.1</version

springboot整合mybatis-爱代码爱编程

序言 基于mybatis-plus代码生成器,不需要配置xml,操作简单,只需要执行main方法即可 本文使用的mybatis-plus-generator版本为3.5.2 代码生成器mybatis-plus-generator介绍 mybatis-plus-generator是 MyBatis-Plus(简称MP)的代码生成

mybatis-爱代码爱编程

前言        在基于Mybatis的开发模式中,很多开发者还会选择Mybatis-Plus来辅助功能开发,以此提高开发的效率。虽然Mybatis也有代码生成的工具,但Mybatis-Plus由于在Mybatis基础上做了一些调整,因此,常规的生成工具生成的代码还有一些不太符合预期。而且对于多数据库的支持不是很好。因此,我们需要一款支持高度定制