一、项目结构(maven项目,选中pom.xml转maven项目add as maven project):
二、项目pom.xml文件
(xml导包错误,可以把dependency拷贝出来改版本在替换,或者改变导包的顺序)
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.5.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.synda</groupId>
<artifactId>MPStudy</artifactId>
<version>1.1.0</version>
<dependencies>
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.0.5</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
</dependencies>
</project>
三、yml数据源配置
server:
port: 8087
spring:
datasource:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/dbdetail?useSSL=false&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&transformedBitIsBoolean=true&serverTimezone=GMT%2B8
username: root
password: 123456
四、启动类添加(@MapperScan注解)
package com;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@MapperScan("com.study.mapper*")
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
五、代码生成器配置(util文件夹下面的CodeGenerator)
执行完代码生成器,然后在写代码(会生成启动类@MapperScan的mapper路径)
controller的父类可以是一些获取Token的代码,Entity的父类可以是一些实体共用的字段可自动填充的
package com.study.util;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
import com.baomidou.mybatisplus.core.toolkit.StringPool;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.InjectionConfig;
import com.baomidou.mybatisplus.generator.config.*;
import com.baomidou.mybatisplus.generator.config.po.TableInfo;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
public class CodeGenerator {
public static void main(String[] args) {
String projectPath=System.getProperty("user.dir");//项目路径,如果项目下面有子项目(应用到配置的地方需要指定子项目名称)
AutoGenerator mpg=new AutoGenerator();//代码生成器
//1、全局配置
//------------------------------------------文件输出位置配置
GlobalConfig gc=new GlobalConfig();
//文件输出路径
gc.setOutputDir(projectPath+"/src/main/java");
//作者信息
gc.setAuthor("zhaoyang");
//是否打开生成目录
gc.setOpen(false);
//开启Swagger2注解
//gc.setSwagger2(true);
//开启 BaseResultMap
gc.setBaseResultMap(true);
//开启BaseColumnList
gc.setBaseColumnList(true);
//是否覆盖已有文件
gc.setFileOverride(true);
//设置主键生成策略IdType.ASSIGN_UUID
gc.setIdType(IdType.ASSIGN_UUID);
//自定义文件命名,注意 %s 会自动填充表实体属性!
gc.setControllerName("%sController");
gc.setServiceName("%sService");
gc.setServiceImplName("%sServiceImpl");
gc.setMapperName("%sMapper");
gc.setXmlName("%sMapper");
mpg.setGlobalConfig(gc);
//2、数据源配置
//------------------------------------------数据库连接配置
DataSourceConfig dsc=new DataSourceConfig();
dsc.setUrl("jdbc:mysql://127.0.0.1:3306/dbdetail?useSSL=false&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&transformedBitIsBoolean=true&serverTimezone=GMT%2B8");
dsc.setDriverName("com.mysql.jdbc.Driver");
dsc.setUsername("root");
dsc.setPassword("123456");
mpg.setDataSource(dsc);
//3、包配置
//------------------------------------------装代码最底层包、项目名称
PackageConfig pc=new PackageConfig();
pc.setModuleName(scanner("study"));//模块名(存放业务代码的最后一层文件夹)
pc.setParent("com");//存放业务代码的最后一层文件夹,父级文件夹(java下面)
mpg.setPackageInfo(pc);
//4、自定义配置
//-------------------------------------------mapper.xml的生成、指定模板路径
InjectionConfig cfg=new InjectionConfig() {
@Override
public void initMap() {
//to do nothing
}
};
//自定义模板需要到 mybatis-plus 官方github仓库中将templates模板下载下来,将需要的模板页面放入工程的resources下的templates文件夹下
//可以在代码生成器中指定模版路径
String templatePath="/templates/mapper.xml.ftl";//????????????????
//自定义输出配置
List<FileOutConfig> focList=new ArrayList<>();
focList.add(new FileOutConfig(templatePath) {
@Override
public String outputFile(TableInfo tableInfo) {
//项目路径+"src/main/resource/mapper"+mapper文件名+.xml
return projectPath+"/src/main/resources/mapper/"+tableInfo.getMapperName()+ StringPool.DOT_XML;
}
});
cfg.setFileOutConfigList(focList);
mpg.setCfg(cfg);
//5、配置模板
//-------------------------------------------生成实体、controller、mapper的模板格式
TemplateConfig templateConfig=new TemplateConfig();
//指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别
templateConfig.setEntity("templates/entity.java");
templateConfig.setController("templates/controller.java");
templateConfig.setMapper("templates/mapper.java");
templateConfig.setXml(null);//设置后xml文件不会生成到java的mapper文件夹下的xml文件夹下面
mpg.setTemplate(templateConfig);
//6、策略配置
//-------------------------------------------
StrategyConfig strategy=new StrategyConfig();
//数据库表映射到实体的命名策略(下划线转驼峰)
strategy.setNaming(NamingStrategy.underline_to_camel);
//数据库表字段映射到实体的命名策略(下划线转驼峰)
strategy.setColumnNaming(NamingStrategy.underline_to_camel);
//生成lombok注解
strategy.setEntityLombokModel(true);
//是否生成实体时,生成字段注解
strategy.setEntityTableFieldAnnotationEnable(true);
//公共Entity父类(实体 extends 父实体)
strategy.setSuperEntityClass("com.study.common.BaseEntity");
//基础类中的公共字段可以不用生成到实体,写在这里可以排出
strategy.setSuperEntityColumns("create_by","create_time","update_by","update_time");
//设置RestController
strategy.setRestControllerStyle(true);//???????????????????
//公共Controller父类(controller extends 父controller)
strategy.setSuperControllerClass("com.study.common.parentController");
//需要包含的表名,允许正则表达式(与exclude二选一配置)
strategy.setInclude(scanner("表名,多个英文逗号分隔").split(","));
//驼峰转连字符
strategy.setControllerMappingHyphenStyle(true);//???????????????????
//生成的实体名称或实体属性不希望带的前缀(如果表名带前缀,生成的会把前缀去掉)
//final String[] CutPrefix = new String[]{"tx_","t_","sys_", "f_"};
strategy.setTablePrefix(pc.getModuleName()+"_");
//strategy.setFieldPrefix(CutPrefix);
mpg.setStrategy(strategy);
//设置模板引擎
mpg.setTemplateEngine(new FreemarkerTemplateEngine());
mpg.execute();
}
/**
* 读取控制台内容
* @param tip
* @return
*/
public static String scanner(String tip){
Scanner scanner=new Scanner(System.in);
//打印输入提示信息
StringBuilder help=new StringBuilder();
help.append("请输入"+tip+":");
System.out.println(help.toString());
//将用户输入的内容返回去
if(scanner.hasNext()){
String ipt=scanner.next();
if(StringUtils.isNotBlank(ipt)){
return ipt;
}
}
throw new MybatisPlusException("请输入正确的"+tip+"!");
}
}