前言

mybatis-plus官网地址

https://baomidou.com

mybatis-plus是mybatis的加强,不对mybatis做任何扭转,涵盖了代码生成,自定义ID生成器,疾速实现CRUD,主动分页,逻辑删除等性能,更多功能请查阅官网文档

装置依赖

mybatis-plus-generator

<!-- more -->

<!-- mybatis plus 代码生成器 --><dependency>    <groupId>com.baomidou</groupId>    <artifactId>mybatis-plus-boot-starter</artifactId>    <version>3.4.3.4</version></dependency><dependency>    <groupId>com.baomidou</groupId>    <artifactId>mybatis-plus-generator</artifactId>    <version>3.5.1</version></dependency>

application.yml增加配置

针对spring boot或者mavan我的项目,咱们须要在我的项目配置文件进行mybatis-plus增加配置项

mybatis-plus:  mapper-locations: classpath*:mapper/**/*Mapper.xml  type-aliases-package: com.lewyon.mybatislewyon.entity  

代码生成实例

代码生成依赖

在代码生成之前,咱们还须要增加mysql等相干包,进行导入,以后实例应用freemarker模板,因而须要增加相干依赖

<!-- mysql --><dependency>    <groupId>mysql</groupId>    <artifactId>mysql-connector-java</artifactId>    <version>8.0.26</version></dependency><!-- freemarker --><dependency>    <groupId>org.freemarker</groupId>    <artifactId>freemarker</artifactId>    <version>2.3.31</version></dependency>

数据源配置

实例化DataSourceConfig办法对数据源进行配置,传入数据库地址和账号密码

private static final DataSourceConfig.Builder DATA_SOURCE_CONFIG = new DataSourceConfig    .Builder("jdbc:mysql://localhost:3306/user?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC", "root", "lewyon123")    .dbQuery(new MySqlQuery()) //数据库查问    .schema("mybatis-plus") //数据库schema(局部数据库实用)    .typeConvert(new MySqlTypeConvert()) //数据库类型转换器    .keyWordsHandler(new MySqlKeyWordsHandler()); //数据库关键字处理器

globalConfig解决通用配置

.globalConfig(builder -> {    builder.author("lewyon") // 设置作者            .enableSwagger() // 开启 swagger 模式            .fileOverride() // 笼罩已生成文件            .disableOpenDir() //禁止关上输入目录            .outputDir(projectPath + "/src/main/java"); // 指定输入目录})

packageConfig包名设置

packageConfig配置项包含父包名,entity,service, serviceImpl, mapper层,

xml配置,控制器controller等。

.packageConfig(builder -> {    builder.parent("com.lewyon.mybatislewyon") // 设置父包名            .moduleName("user") // 设置父包模块名            .entity("entity")            .service("service")            .serviceImpl("service.impl")            .mapper("mapper")            .xml("mapper.xml")            .controller("controller");})

strategyConfig配置

  • strategyConfig配置设置包含表名称以及表名解决
  • 格式化Service以及ServiceImpl,增加%s前缀示意去除 Service 前缀的I
.strategyConfig(builder -> {    builder.addInclude("user") // 设置须要生成的表名            .addTablePrefix("t_", "c_").controllerBuilder()            .enableHyphenStyle()            .enableRestStyle()            .serviceBuilder()            .formatServiceFileName("%sService")            .formatServiceImplFileName("%sServiceImp")            .build();})

小结

以上就是对于mybatis-plus生成代码包的根底实例,残缺代码如下:

package com.lewyon.mybatislewyon;import com.baomidou.mybatisplus.generator.FastAutoGenerator;import com.baomidou.mybatisplus.generator.config.DataSourceConfig;import com.baomidou.mybatisplus.generator.config.converts.MySqlTypeConvert;import com.baomidou.mybatisplus.generator.config.querys.MySqlQuery;import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;import com.baomidou.mybatisplus.generator.engine.VelocityTemplateEngine;import com.baomidou.mybatisplus.generator.keywords.MySqlKeyWordsHandler;public class GeneratorCode {    /**     * 数据源配置     */    private static final DataSourceConfig.Builder DATA_SOURCE_CONFIG = new DataSourceConfig            .Builder("jdbc:mysql://localhost:3306/user?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC", "root", "lewyon123")            .dbQuery(new MySqlQuery()) //数据库查问            .schema("mybatis-plus") //数据库schema(局部数据库实用)            .typeConvert(new MySqlTypeConvert()) //数据库类型转换器            .keyWordsHandler(new MySqlKeyWordsHandler()); //数据库关键字处理器    public static void main(String[] args) {        String projectPath = System.getProperty("user.dir");        FastAutoGenerator.create(DATA_SOURCE_CONFIG)                .globalConfig(builder -> {                    builder.author("lewyon") // 设置作者                            .enableSwagger() // 开启 swagger 模式                            .fileOverride() // 笼罩已生成文件                            .disableOpenDir() //禁止关上输入目录                            .outputDir(projectPath + "/src/main/java"); // 指定输入目录                })                .packageConfig(builder -> {                    builder.parent("com.lewyon.mybatislewyon") // 设置父包名                            .moduleName("user") // 设置父包模块名                            .entity("entity")                            .service("service")                            .serviceImpl("service.impl")                            .mapper("mapper")                            .xml("mapper.xml")                            .controller("controller");                })                .strategyConfig(builder -> {                    builder.addInclude("user") // 设置须要生成的表名                            .addTablePrefix("t_", "c_").controllerBuilder()                            .enableHyphenStyle()                            .enableRestStyle()                            .serviceBuilder()                            .formatServiceFileName("%sService")                            .formatServiceImplFileName("%sServiceImp")                            .build();                })                .templateEngine(new FreemarkerTemplateEngine()) // 应用Freemarker引擎模板,默认的是Velocity引擎模板                .execute();    }}

mybatis-plus生成代码以后实例只针对单表查问,表字段为:id,name,这里表构造不做独自列举,须要的同学请自行建表处理。

总结

我的项目源码地址:

https://gitee.com/lewyon/spring-note

文章博客地址:spring boot我的项目应用mybatis-plus代码生成实例

我的项目源码蕴含了swagger,后续更新对于spring boot集成swagger根底实例

欢送关注公众号:程序员布欧,不定期更新技术入门文章

创作不易,转载请注明出处和作者。