首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
SAAS
ToB门户
了解全球最新的ToB事件
论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
微博
Follow
记录
Doing
博客
Blog
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
排行榜
Ranklist
相册
Album
应用中心
qidao123.com ToB IT社区-企服评测·应用市场
»
论坛
›
软件与程序人生
›
后端开发
›
Java
›
MyBatis plus 代码生成器
返回列表
发新帖
MyBatis plus 代码生成器
[复制链接]
发表于 2023-2-21 00:16:36
|
显示全部楼层
|
阅读模式
导入依赖
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.4.1</version>
</dependency>
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>2.3</version>
</dependency>
复制
代码
写一个类 Generator ,名字叫什么都行,写在哪里也都可以,在这个类里面写main方法,运行main方法即可生成
代码
,内容如下:
public static void main(String[] args) {
//获取
代码
生成器对象
AutoGenerator autoGenerator = new AutoGenerator();
//设置
数据库
相关
配置
DataSourceConfig dataSource = new DataSourceConfig();
dataSource.setDriverName("com.mysql.cj.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/db?serverTimezone=UTC");
dataSource.setUsername("root");
dataSource.setPassword("1234");
autoGenerator.setDataSource(dataSource);
//设置全局
配置
GlobalConfig globalConfig = new GlobalConfig();
globalConfig.setOutputDir(System.getProperty("user.dir") + "/src/main/java");//设置代码输出位置,否则默认输出到D://目录下
globalConfig.setOpen(false);//设置生成完毕后是否打开生成代码的目录,一般选择false,不需要打开目录
globalConfig.setAuthor("tuuli");//作者名字,会在注释中添加作者名字
globalConfig.setFileOverride(true);//是否覆盖原始生成的文件,选择true后,生成时若原来已有相同文件会自动覆盖,谨慎操作
globalConfig.setMapperName("%sDao");//设置数据层接口名,%s为占位符,指代模块名称,默认为"%sMapper"
globalConfig.setIdType(IdType.AUTO);//设置id生成策略
autoGenerator.setGlobalConfig(globalConfig);
//设置包名
配置
PackageConfig packageConfig = new PackageConfig();
packageConfig.setParent("com.tuuli");//设置生成的包名,默认为"com.baomidou"
packageConfig.setEntity("domain");//设置实体类包名,默认为entity
packageConfig.setMapper("dao");//设置数据层包名,默认为mapper
autoGenerator.setPackageInfo(packageConfig);
//策略设置
StrategyConfig strategyConfig = new StrategyConfig();
strategyConfig.setInclude("tb_course");//设置参与生成的表名,可填一个或多个
strategyConfig.setTablePrefix("tb_");//设置
数据库
表名的前缀名称,设置后会省略该前缀
strategyConfig.setRestControllerStyle(false);//设置是否启用Rest风格
//strategyConfig.setLogicDeleteFieldName("deleted");//设置逻辑删除字段名,没有就不填
strategyConfig.setEntityLombokModel(true);//设置是否启用Lombok
autoGenerator.setStrategy(strategyConfig);
//执行生成操作
autoGenerator.execute();
}
复制代码
测试
新建一个springboot项目,导入相关依赖坐标,初始时目录结构如下:
新建
数据库
,数据名db3,新建了两个表,分别为tb_user、tb_course,表结构如下:
tb_user
tb_course
表中内容均为空。
生成代码,此处代码生成器的完整代码的如下:
package com.tuuli;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
import com.baomidou.mybatisplus.generator.config.PackageConfig;
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
/**
* @author tuuli
* @time Created in 2023/2/20 23:21
* @description
*/
public class Generator {
public static void main(String[] args) {
//获取代码生成器对象
AutoGenerator autoGenerator = new AutoGenerator();
//设置数据库相关配置
DataSourceConfig dataSource = new DataSourceConfig();
dataSource.setDriverName("com.mysql.cj.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/db3?serverTimezone=UTC");
dataSource.setUsername("root");
dataSource.setPassword("1234");
autoGenerator.setDataSource(dataSource);
//设置全局配置
GlobalConfig globalConfig = new GlobalConfig();
globalConfig.setOutputDir(System.getProperty("user.dir") + "/src/main/java");//设置代码输出位置,否则默认输出到D://目录下
globalConfig.setOpen(false);//设置生成完毕后是否打开生成代码的目录,一般选择false,不需要打开目录
globalConfig.setAuthor("tuuli");//作者名字,会在注释中添加作者名字
globalConfig.setFileOverride(true);//是否覆盖原始生成的文件,选择true后,生成时若原来已有相同文件会自动覆盖,谨慎操作
globalConfig.setMapperName("%sDao");//设置数据层接口名,%s为占位符,指代模块名称,默认为"%sMapper"
globalConfig.setIdType(IdType.AUTO);//设置id生成策略
autoGenerator.setGlobalConfig(globalConfig);
//设置包名配置
PackageConfig packageConfig = new PackageConfig();
packageConfig.setParent("com.tuuli");//设置生成的包名,默认为"com.baomidou"
packageConfig.setEntity("domain");//设置实体类包名,默认为entity
packageConfig.setMapper("dao");//设置数据层包名,默认为mapper
autoGenerator.setPackageInfo(packageConfig);
//策略设置
StrategyConfig strategyConfig = new StrategyConfig();
strategyConfig.setInclude("tb_course", "tb_user");//设置参与生成的表名,可填一个或多个
strategyConfig.setTablePrefix("tb_");//设置数据库表名的前缀名称,设置后会省略该前缀
strategyConfig.setRestControllerStyle(false);//设置是否启用Rest风格
//strategyConfig.setLogicDeleteFieldName("deleted");//设置逻辑删除字段名,没有就不填
strategyConfig.setEntityLombokModel(true);//设置是否启用Lombok
autoGenerator.setStrategy(strategyConfig);
//执行生成操作
autoGenerator.execute();
}
}
复制代码
运行成功,目录内容已发生改变,已生成相关代码
controller层代码:
dao层代码(请手动添加@Mapper注解,否则后面会出错):
domain层代码:
mapper.xml
service接口:
service实现类:
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
×
回复
使用道具
举报
返回列表
浏览过的版块
鸿蒙
熊熊出没
+ 我要发帖
登录后关闭弹窗
登录参与点评抽奖 加入IT实名职场社区
去登录
微信订阅号
微信服务号
微信客服(加群)
H5
小程序
快速回复
返回顶部
返回列表