网站首页 > 技术文章 正文
官方文档地址
https://baomidou.com/pages/981406/#%E6%95%B0%E6%8D%AE%E5%BA%93%E9%85%8D%E7%BD%AE-datasourceconfig
数据库测试SQL
create database my_app collate utf8mb4_bin;
use my_app;
create table m_user(user_id bigint primary key auto_increment,username varchar(32) not null );
# 修改表
alter table m_user add create_time bigint null comment '创建时间';
alter table m_user add update_time bigint null comment '更新时间';
alter table m_user add version int null comment '乐观锁版本';
alter table m_user add deleted int comment '逻辑删除';
build.gradle
dependencies {
runtimeOnly 'mysql:mysql-connector-java:8.0.33'
implementation 'com.baomidou:mybatis-plus-boot-starter:3.5.3.1'
implementation 'com.baomidou:mybatis-plus-generator:3.5.3.1'
implementation 'org.freemarker:freemarker:2.3.31'
implementation 'org.apache.velocity:velocity-engine-core:2.3'
}
代码
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import com.baomidou.mybatisplus.generator.fill.Column;
import com.baomidou.mybatisplus.generator.fill.Property;
public class MainApplication {
private static String driver = "com.mysql.cj.jdbc.Driver";
public static void main(String[] args) throws Exception {
Class.forName(driver);
FastAutoGenerator.create(
"jdbc:mysql://127.0.0.1:3306/my_app?serverTimezone=GMT%2B8&characterEncoding=utf8&useSSL=false&allowPublicKeyRetrieval=true",
"root", "2023")
.globalConfig(
builder -> {
builder
.disableOpenDir()
.author("ms") // 设置作者
.fileOverride() // 覆盖已生成文件
.outputDir("gen/src/main/java"); // 指定输出目录
})
.packageConfig(
builder -> {
// 设置父包名
builder.parent("com.my.app.mysql");
builder.moduleName("my_app");
})
.strategyConfig(
builder -> {
// 数据库表
builder.addInclude("m_user");
builder.entityBuilder().idType(IdType.ASSIGN_ID);
builder.entityBuilder().logicDeleteColumnName("deleted");
builder.entityBuilder().logicDeletePropertyName("deleted");
builder.entityBuilder().versionColumnName("version");
builder.entityBuilder().versionPropertyName("version");
builder.entityBuilder().enableChainModel();
builder.entityBuilder().addTableFills(new Column("create_time", FieldFill.INSERT));
builder.entityBuilder().addTableFills(new Property("update_time", FieldFill.INSERT_UPDATE));
builder.entityBuilder().enableFileOverride();
})
.templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
.execute();
}
}
完整案例github地址
https://github.com/code-mm/mybatis-plus-codegen-example.git
猜你喜欢
- 2024-09-29 MybatisPlus—kotlin代码生成 mybatisplus 代码生成器
- 2024-09-29 Spring boot Mybatis 整合 springboot整合mybatis流程
- 2024-09-29 SpringBoot使用Mybatis-FreeMarker
- 2024-09-29 MyBatis自动生成Mapper插件 mybatis 生成mapper
- 2024-09-29 增强Mybatis常用方案 mybatis-plus扩展
- 2024-09-29 网易架构师吐血整理:2分钟看完Mybatis核心知识点
- 2024-09-29 Mybatis的XML映射文件的继承问题 mybatis映射文件的主要元素及作用
- 2024-09-29 Mybatis 自动生成bean mybatis 自动生成bo
- 2024-09-29 深入理解Python生成器(Generators)
- 2024-09-29 如何避免出现 SQL 注入漏洞 怎样避免sql注入
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)