共计 4434 个字符,预计需要花费 12 分钟才能阅读完成。
前言
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 根底实例
欢送关注公众号: 程序员布欧 ,不定期更新技术入门文章
创作不易,转载请注明出处和作者。