<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>Latest Version</version>
</dependency>
FastAutoGenerator.create("url", "username", "password")
.globalConfig(builder -> {
builder.author("L.cm")
.dateType(DateType.TIME_PACK)
.fileOverride()
.outputDir("目录");
})
.packageConfig(builder -> {
builder.parent("net.xxxx.project")
.moduleName("system");
})
.strategyConfig(builder -> {
builder.addInclude("sys_xxx")
.entityBuilder()
.enableLombok()
.superClass(BaseModel.class)
.addSuperEntityColumns("id", "created_by", "created_at", "updated_by", "updated_at")
.naming(NamingStrategy.underline_to_camel)
.controllerBuilder()
.superClass(BaseController.class)
.enableRestStyle()
.enableHyphenStyle()
.mapperBuilder()
.enableMapperAnnotation()
.enableBaseResultMap()
.enableBaseColumnList()
;
})
.templateEngine(new FreemarkerTemplateEngine())
.execute();
new SimpleAutoGenerator() {
@Override
public IConfigBuilder<DataSourceConfig> dataSourceConfigBuilder() {
return new DataSourceConfig.Builder("jdbc:h2:mem:test;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE;CASE_INSENSITIVE_IDENTIFIERS=TRUE",
"sa", "");
}
}.execute();
属性 | 说明 | 示例 |
---|---|---|
url | jdbc路径 | jdbc:mysql://127.0.0.1:3306/mybatis-plus |
username | 数据库账号 | root |
password | 数据库密码 | 123456 |
new DataSourceConfig.
Builder("jdbc:mysql://127.0.0.1:3306/mybatis-plus","root","123456").build();
方法 | 说明 | 示例 |
---|---|---|
driver | 数据库驱动 | Driver.class 或 com.mysql.jdbc.Driver |
dbType | 数据库类型 | DbType.MYSQL |
typeConvert | 数据库类型转换器 | new MySqlTypeConvert() |
keyWordsHandler | 数据库关键字处理器 | new MySqlKeyWordsHandler() |
dbQuery | 数据库查询 | new MySqlQuery() |
schema | 数据库schema(部分数据库适用) | mybatis-plus |
new DataSourceConfig
.Builder("jdbc:mysql://127.0.0.1:3306/mybatis-plus","root","123456")
.driver(Driver.class)
.dbType(DbType.MYSQL)
.typeConvert(new MySqlTypeConvert())
.keyWordsHandler(new MySqlKeyWordsHandler())
.dbQuery(new MySqlQuery())
.schema("mybatis-plus")
.build();
方法 | 说明 | 示例 |
---|---|---|
fileOverride | 是否覆盖已生成文件 | 默认值:false |
openDir | 是否打开生成目录 | 默认值:true |
outputDir | 指定输出目录 | /opt/baomidou/ 默认值: windows:D:// linux or mac : /tmp |
author | 作者名 | baomidou 默认值:无 |
kotlin | 是否生成kotlin | 默认值:false |
swagger | 是否生成swagger注解 | 默认值:false |
dateType | 时间策略 | DateType.ONLY_DATE 默认值: DateType.TIME_PACK |
commentDate | 注释日期 | 默认值: yyyy-MM-dd |
GeneratorBuilder.globalConfigBuilder()
.fileOverride(true).openDir(true).kotlin(false).swagger(true)
.outputDir("/opt/baomidou")
.author("baomidou").dateType(DateType.TIME_PACK).commentDate("yyyy-MM-dd")
.build();
方法 | 说明 | 示例 |
---|---|---|
parent | 父包名 | 默认值:com.baomidou |
moduleName | 父包模块名 | sys 默认值:无 |
entity | Entity包名 | 默认值:entity |
service | Service包名 | 默认值:service |
serviceImpl | Service Impl包名 | 默认值:service.impl |
mapper | Mapper包名 | 默认值:mapper |
xml | Mapper XML包名 | 默认值:mapper.xml |
controller | Controller包名 | 默认值:controller |
new PackageConfig.Builder().parent("com.baomidou.mybatisplus.samples.generator").moduleName("sys").build();
方法 | 说明 | 示例 |
---|---|---|
all | 激活所有默认模板 | |
entity | 使用默认实体模板 | /templates/entity |
entity(string) | 使用自定义实体模板 | |
service | 使用默认配套service模板 | /templates/service.java,/templates/serviceImpl.java |
service(string,string) | 使用自定义service模板 | |
mapper | 使用默认mapper模板 | /templates/mapper.java |
mapper(string) | 使用自定义mapper模板 | |
mapperXml | 使用默认mapperXml模板 | /templates/mapper.xml |
mapperXml(string) | 使用自定义mapperXml模板 | |
controller | 使用默认controller模板 | /templates/controller.java |
controller(string) | 使用自定义controller模板 |
new TemplateConfig.Builder().all().build(); //激活所有默认模板
方法 | 说明 | 示例 |
---|---|---|
enableCapitalMode | 开启大写命名 | |
enableSkipView | 开启跳过视图 | |
disableSqlFilter | 禁用sql过滤 | 语法不能支持使用sql过滤表的话,可以考虑关闭此开关. |
likeTable | 模糊表匹配(sql过滤) | |
notLikeTable | 模糊表排除(sql过滤) | |
addFieldPrefix(string...) | 增加表字段前缀 | |
addInclude(string...) | 增加表匹配(内存过滤) | |
addExclude(string...) | 增加表排除匹配(内存过滤) | |
addTablePrefix(string...) | 增加表前缀 | |
entityBuilder | 实体策略配置 | |
controllerBuilder | controller策略配置 | |
mapperBuilder | mapper策略配置 | |
serviceBuilder | service策略配置 |
方法 | 说明 | 示例 |
---|---|---|
nameConvert | 名称转换实现 | |
superClass | 父类 | |
enableSerialVersionUID | 开启生成serialVersionUID | |
enableColumnConstant | 开启生成字段常量 | |
enableChainModel | 开启链式模型 | |
enableLombok | 开启lombok模型 | |
enableRemoveIsPrefix | 开启Boolean类型字段移除is前缀 | |
enableTableFieldAnnotationEnable | 开启生成实体时生成字段注解 | |
versionColumnName(string) | 乐观锁字段名(数据库) | |
versionPropertyName(string) | 乐观锁属性名(实体) | |
logicDeleteColumnName(string) | 逻辑删除字段名(数据库) | |
logicDeletePropertyName(string) | 逻辑删除属性名(实体) | |
naming | 数据库表映射到实体的命名策略 | 默认:NamingStrategy.no_change |
columnNaming | 数据库表字段映射到实体的命名策略 | |
addSuperEntityColumns(string...) | 添加父类公共字段 | |
addTableFills(IFill...) | 添加属性填充字段 | |
enableActiveRecord | 开启ActiveRecord模型 | |
idType | 全局主键类型 | |
convertFileName | 转换文件名称 | |
formatFileName | 格式化文件名称 |
方法 | 说明 | 示例 |
---|---|---|
superClass | 父类 | |
enableHyphenStyle | 开启驼峰转连字符 | |
enableRestStyle | 开启生成@RestController控制器 | |
convertFileName | 转换文件名称 | |
formatFileName | 格式化文件名称 |
方法 | 说明 | 示例 |
---|---|---|
superServiceClass | 设置service接口父类 | |
superServiceImplClass | 设置service实现类父类 | |
convertServiceFileName | 转换service接口文件名称 | |
convertServiceImplFileName | 转换service实现类文件名称 | |
formatServiceFileName | 格式化service接口文件名称 | |
formatServiceImplFileName | 格式化service实现类文件名称 |
方法 | 说明 | 示例 |
---|---|---|
superClass | 设置父类 | |
enableBaseResultMap | 启用BaseResultMap生成 | |
enableBaseColumnList | 启用BaseColumnList | |
cache | 设置缓存实现类 | |
formatMapperFileName | 格式化mapper文件名称 | |
formatXmlFileName | 格式化xml实现类文件名称 | |
convertMapperFileName | 转换mapper类文件名称 | |
convertXmlFileName | 转换xml文件名称 |
new StrategyConfig.Builder()
.enableSqlFilter(true)// 启用sql过滤
.capitalMode(true)// 是否大写命名
.entityBuilder()// 实体配置构建者
.enableLombok()// 开启lombok模型
.versionColumnName("version") //乐观锁数据库表字段
.naming(NamingStrategy.underline_to_camel)// 数据库表映射到实体的命名策略
.addTableFills(new Column("create_time", FieldFill.INSERT)) //基于数据库字段填充
.addTableFills(new Property("updateTime", FieldFill.INSERT_UPDATE)) //基于模型属性填充
.controllerBuilder() //控制器属性配置构建
.restStyle(true)
.build();