mybatisplus代码生成器3.5.8
时间: 2025-04-25 22:35:14 浏览: 25
### MyBatisPlus 代码生成器 3.5.8 下载及使用说明
#### Maven依赖配置
为了集成MyBatisPlus代码生成器到项目中,需在`pom.xml`文件内加入如下依赖:
```xml
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.5.8</version>
</dependency>
<!-- 引擎模板 -->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
</dependency>
```
上述配置指定了MyBatisPlus代码生成器的具体版本为3.5.8,并引入了FreeMarker作为模板引擎用于生成代码[^2]。
#### 配置数据库连接信息
通常,在Spring Boot应用中的`application.yml`或`application.properties`里定义数据源参数。对于MySQL 8.x环境下的设置示例如下(YAML格式):
```yaml
spring:
datasource:
url: jdbc:mysql://localhost:3306/your_database?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
username: root
password: your_password
driver-class-name: com.mysql.cj.jdbc.Driver
```
此部分确保应用程序能够正确访问目标数据库并执行相应的DDL/DML操作[^1]。
#### 编写Java程序启动代码生成过程
创建一个新的类来初始化和运行代码生成功能。下面是一个简单的例子展示如何实现这一点:
```java
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;
public class CodeGenerator {
public static void main(String[] args) {
AutoGenerator mpg = new AutoGenerator();
// 设置全局配置
GlobalConfig gc = new GlobalConfig();
String projectPath = System.getProperty("user.dir");
gc.setOutputDir(projectPath + "/src/main/java"); // 输出路径设为当前项目的根目录下的/src/main/java/
gc.setAuthor("Your Name Here"); // 开发者姓名
gc.setOpen(false); // 是否打开输出目录,默认false
mpg.setGlobalConfig(gc);
// 数据库配置
DataSourceConfig dsc = new DataSourceConfig();
dsc.setUrl("jdbc:mysql://localhost:3306/your_database?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai");
dsc.setDriverName("com.mysql.cj.jdbc.Driver");
dsc.setUsername("root");
dsc.setPassword("your_password");
mpg.setDataSource(dsc);
// 包名策略配置
PackageConfig pc = new PackageConfig();
pc.setParent("com.example.demo") // 自定义父包名称
.setModuleName(null) // 不指定模块名则默认为空
.setEntity("model") // 实体类所在的子包名为model
.setMapper("mapper") // Mapper接口所在子包名为mapper
.setService("service") // Service层接口及其Impl实现类所处位置分别为service和服务实现类的impl
.setController("controller"); // Controller控制器放置于controller子包之下
mpg.setPackageInfo(pc);
// 表策略配置
StrategyConfig strategy = new StrategyConfig();
strategy.setNaming(/*命名规则*/)
.setColumnNaming(/*列名转换方式*/)
.setInclude(new String[]{"table_name"}) // 只针对特定表进行代码生成
.setRestControllerStyle(true) // REST风格API设计模式支持
.entityTableFieldAnnotationEnable(true); // 启用实体字段上的@TableField注解自动生成功能
mpg.setStrategy(strategy);
// 执行代码生成
mpg.execute();
}
}
```
这段代码展示了怎样通过编程的方式调用AutoGenerator对象完成整个流程控制,包括但不限于设定基础属性、链接至外部资源以及制定具体的业务逻辑处理方案等细节[^3]。
阅读全文
相关推荐














