这个版本的代码生成器我并未采用最新的3.5.1版本,而是旧版本 ,新版本代码生成器 可以直接去官网看文档即可
以下是代码生产所需的依赖、配置、代码段
、、、依赖、、
<!-- mybatis plus-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.0</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.4.0</version>
</dependency>
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>2.3</version>
</dependency>
</dependencies>
新建项目的时候,我勾选了 web mysql 和 lombok 这三个
application.yml文件的配置
注意:这里,如果拿过去用的话 需要修改的地方只有一个 那就是 数据库的名称 我这里是 mybatis_plus 只需要修改为你的数据库文件即可
另外端口可以不设置也行吧
上方我做了生产和测试的隔离但是我这里没有用到 也可以删除掉,看你个人的需要
spring:
profiles:
active: dev
datasource:
password: root
username: root
url: jdbc:mysql://localhost:3306/mybatis_plus?useSSL=flase&useUnicode=true&characterEncodeing=utf-8&serverTimezone=Asia/Shanghai
driver-class-name: com.mysql.cj.jdbc.Driver
type: com.alibaba.druid.pool.DruidDataSource
#server port
server:
port: 9000
#mybatisplus log
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
#luojishanchu
global-config:
db-config:
logic-not-delete-value: 0
logic-delete-value: 1
Config文件的配置
这些都是固定的写法 ,如果有自己需要的组件 也可以自己进行配置 Bean 即可
@MapperScan("com.yuan.Blog.mapper")
@EnableTransactionManagement
@Configuration
public class MybatisPlusConfig {
@Bean
public PaginationInnerInterceptor paginationInnerInterceptor(){
PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();
return paginationInnerInterceptor;
}
}
main.java
主文件的修改地方是数据源中数据库的名称,以及你的数据库用户名和密码
另外如果你有多个数据库表需要生成,那么只需要在策略配置中 映射字段 添加进入即可 格式如下
strategyConfig.setInclude("user","priece"..........)
public class codeTest {
public static void main(String[] args) {
//构建代码生成器
AutoGenerator mp = new AutoGenerator();
//全局文件配置
GlobalConfig globalConfig = new GlobalConfig();
globalConfig.setOutputDir(System.getProperty("user.dir") + "/src/main/java");
globalConfig.setAuthor("yuan");
globalConfig.setOpen(false);
globalConfig.setServiceName("%sService"); //去前缀
globalConfig.setIdType(IdType.ASSIGN_ID);
globalConfig.setDateType(DateType.ONLY_DATE);
mp.setGlobalConfig(globalConfig);
//数据源配置
DataSourceConfig dataSourceConfig = new DataSourceConfig();
dataSourceConfig.setUrl("jdbc:mysql://localhost:3306/mybatis_plus?useUnicode=true&useSSL=false&characterEncoding=utf8");
dataSourceConfig.setDriverName("com.mysql.jdbc.Driver");
dataSourceConfig.setUsername("root");
dataSourceConfig.setPassword("root");
mp.setDataSource(dataSourceConfig);
//包配置
PackageConfig packageConfig = new PackageConfig();
packageConfig.setModuleName("Blog");
packageConfig.setParent("com.yuan");
packageConfig.setEntity("pojo");
packageConfig.setController("controller");
packageConfig.setMapper("mapper");
packageConfig.setService("service");
packageConfig.setServiceImpl("serviceimpl");
mp.setPackageInfo(packageConfig);
//策略配置
StrategyConfig strategyConfig = new StrategyConfig();
strategyConfig.setInclude("user");//设置要映射的表名字
strategyConfig.setNaming(NamingStrategy.underline_to_camel);
strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel);
// strategyConfig.setSuperEntityClass("你自己的父类实体,没有则不设置");
strategyConfig.setEntityLombokModel(true);//自动lombok
// strategyConfig.setRestControllerStyle(true);
strategyConfig.setLogicDeleteFieldName("deleted");
strategyConfig.setRestControllerStyle(true);//驼峰命名
strategyConfig.setControllerMappingHyphenStyle(true);//url下划线
//自动填充配置
TableFill update = new TableFill("update", FieldFill.INSERT_UPDATE);
TableFill creat = new TableFill("creat", FieldFill.INSERT);
ArrayList<TableFill> tableFills = new ArrayList<>();
tableFills.add(creat);
tableFills.add(update);
strategyConfig.setTableFillList(tableFills);
//乐观锁配置
strategyConfig.setVersionFieldName("version");//乐观锁
mp.setStrategy(strategyConfig);
mp.execute();
}
}
运行完成后 得到如下