MybatisPlus如何自動(dòng)生成映射文件
如何自動(dòng)生成映射文件
一、pom.xml
pom.xml添加以下依賴:
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.0.1</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.0.3</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus</artifactId>
<version>3.0.3</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.3.2</version>
</dependency>
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.23</version>
</dependency>
<!-- 高版本mybatis plus將這個(gè)包摘出來了,所以需要添加此依賴,低版本不需要 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
</dependency>
二、MybatisPlusUtil工具類
package com.yss.datamiddle.common;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.*;
import com.baomidou.mybatisplus.generator.config.querys.DB2Query;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
/**
* @description: 數(shù)據(jù)庫生成JAVA類
* @create: 2020-07-20 14:00:00
* @update: 2020-07-20 14:00:00
*/
public class MybatisPlusUtils {
/**
* mysql自動(dòng)代碼生成類
*
* @param includeTables
* @param excludeTables
*/
public static void generateMysql(String[] includeTables, String[] excludeTables, Boolean db1) {
AutoGenerator autoGenerator = new AutoGenerator();
/**
* 數(shù)據(jù)庫配置
*/
buildMysqlDb(autoGenerator);
StrategyConfig strategyConfig = new StrategyConfig();
// 駝峰命名
strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel);
strategyConfig.setNaming(NamingStrategy.underline_to_camel);
strategyConfig.setInclude(includeTables);
strategyConfig.setExclude(excludeTables);
strategyConfig.setTablePrefix("");
autoGenerator.setStrategy(strategyConfig);
/**
* 全局配置
*/
GlobalConfig globalConfig = new GlobalConfig();
globalConfig.setAuthor("Han LiDong");
globalConfig.setDateType(DateType.ONLY_DATE);
globalConfig.setActiveRecord(true);
globalConfig.setIdType(IdType.INPUT);
globalConfig.setOutputDir("C:/D/ORM"); //文件生成路徑
globalConfig.setMapperName("%sMapper");
globalConfig.setServiceName("%sService");
globalConfig.setServiceImplName("%sServiceImpl");
globalConfig.setXmlName("%sMapper");
globalConfig.setSwagger2(true);
globalConfig.setFileOverride(true);
globalConfig.setBaseColumnList(false);
globalConfig.setBaseResultMap(false);
globalConfig.setEnableCache(false);
autoGenerator.setGlobalConfig(globalConfig);
/**
* 包名配置
*/
PackageConfig packageConfig = new PackageConfig();
packageConfig.setParent("");
packageConfig.setEntity("com.yss.datamiddle.entity");
packageConfig.setMapper("com.yss.datamiddle.dao");
packageConfig.setXml("mapper");
packageConfig.setService("com.yss.datamiddle.service");
packageConfig.setServiceImpl("com.yss.datamiddle.impl");
packageConfig.setController("com.yss.datamiddle.controller");
autoGenerator.setPackageInfo(packageConfig);
// 采用默認(rèn)模板,自定義模板參考@see com.baomidou.mybatisplus.generator.config.TemplateConfig
// TemplateConfig templateConfig = new TemplateConfig();
autoGenerator.setTemplateEngine(new FreemarkerTemplateEngine());
autoGenerator.execute();
}
/**
* oracle自動(dòng)代碼生成類
* @param includeTables
* @param excludeTables
*/
public static void generateOracle(String[] includeTables, String[] excludeTables, Boolean db1) {
AutoGenerator autoGenerator = new AutoGenerator();
buildOracleDb(autoGenerator);
StrategyConfig strategyConfig = new StrategyConfig();
// 駝峰命名
strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel);
strategyConfig.setNaming(NamingStrategy.underline_to_camel);
strategyConfig.setInclude(includeTables);
strategyConfig.setExclude(excludeTables);
strategyConfig.setTablePrefix("");
autoGenerator.setStrategy(strategyConfig);
/**
* 全局配置
*/
GlobalConfig globalConfig = new GlobalConfig();
globalConfig.setAuthor("Han LiDong");
globalConfig.setDateType(DateType.ONLY_DATE);
globalConfig.setActiveRecord(true);
globalConfig.setIdType(IdType.AUTO); //這里用oracle的序列和觸發(fā)器實(shí)現(xiàn)主鍵自增
globalConfig.setOutputDir("C:/ORM"); //文件生成路徑
globalConfig.setMapperName("%sMapper");
globalConfig.setServiceName("%sService");
globalConfig.setServiceImplName("%sServiceImpl");
globalConfig.setXmlName("%sMapper");
globalConfig.setSwagger2(true);
globalConfig.setFileOverride(true);
globalConfig.setBaseColumnList(false);
globalConfig.setBaseResultMap(false);
globalConfig.setEnableCache(false);
autoGenerator.setGlobalConfig(globalConfig);
/**
* 包名配置
*/
PackageConfig packageConfig = new PackageConfig();
packageConfig.setParent("");
packageConfig.setEntity("com.yss.datamiddle.entity");
packageConfig.setMapper("com.yss.datamiddle.dao");
packageConfig.setXml("mapper");
packageConfig.setService("com.yss.datamiddle.service");
packageConfig.setServiceImpl("com.yss.datamiddle.impl");
packageConfig.setController("com.yss.datamiddle.controller");
autoGenerator.setPackageInfo(packageConfig);
// 采用默認(rèn)模板,自定義模板參考@see com.baomidou.mybatisplus.generator.config.TemplateConfig
// TemplateConfig templateConfig = new TemplateConfig();
autoGenerator.setTemplateEngine(new FreemarkerTemplateEngine());
autoGenerator.execute();
}
private static void buildOracleDb(AutoGenerator autoGenerator) {
DataSourceConfig dataSourceConfig = new DataSourceConfig();
dataSourceConfig.setDbQuery(new MyDbQuery()); //自定義dbquery不然querydb.dbtype找不到
dataSourceConfig.setDbType(DbType.ORACLE);
dataSourceConfig.setDriverName("oracle.jdbc.driver.OracleDriver");
dataSourceConfig.setUsername("xxxxx");
dataSourceConfig.setPassword("xxxxx");
dataSourceConfig.setUrl("jdbc:oracle:thin:@192.168.xxx.xxx/orcl");
//dataSourceConfig.setUrl("jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false");
autoGenerator.setDataSource(dataSourceConfig);
}
private static void buildMysqlDb(AutoGenerator autoGenerator) {
DataSourceConfig dataSourceConfig = new DataSourceConfig();
dataSourceConfig.setDbType(DbType.MYSQL);
dataSourceConfig.setDriverName("com.mysql.jdbc.Driver");
dataSourceConfig.setUsername("root");
dataSourceConfig.setPassword("123456");
dataSourceConfig.setUrl("jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false");
autoGenerator.setDataSource(dataSourceConfig);
}
public static void main(String[] args) {
//String[] includeTables = {"hr_kpi_dept_person","sys_user"};
String[] includeTables = {"ETL_MIDDLE_STATE"};
//generateMysql(includeTables,null,false); //mysql映射文件生成
generateOracle(includeTables,null,false); //oracle映射文件生成
}
}
右鍵 Run 運(yùn)行之后就會(huì)生成一堆映射文件,將之copy到自己的項(xiàng)目中就可以了

注意: 生成的dao層文件需要自己添加@Mapper注解
自動(dòng)映射autoMappingBehavior與mapUnderscoreToCamelCase
autoMappingBehavior
在Mybatis的配置文件中添加settings屬性的autoMappingBehavior
<settings> <setting name="autoMappingBehavior" value="NONE"/> </settings>

autoMappingBehavior有三個(gè)屬性(默認(rèn)是PARTIAL)
NONE:取消自動(dòng)映射PARTIAL:只會(huì)自動(dòng)映射,沒有定義嵌套結(jié)果集映射的結(jié)果集FULL:會(huì)自動(dòng)映射任意復(fù)雜的結(jié)果集(無論是否嵌套)
自動(dòng)映射的時(shí)候sql語句的結(jié)果集字段是不區(qū)分大小寫的,所以映射的pojo成員變量也不需要區(qū)分大小寫,都可以映射到。
mapUnderscoreToCamelCase
如果數(shù)據(jù)庫符合命名規(guī)范,即每個(gè)單詞之間用下劃線連接,pojo類符合駝峰式命名,就可以設(shè)置mapUnderscoreToCamelCase為true,這樣就可以自動(dòng)映射。
不用再給select語句的結(jié)果集字段起別名來對(duì)應(yīng)pojo類的成員
一個(gè)配置完整的 settings 元素的示例如下:
<settings> <setting name="cacheEnabled" value="true"/> <setting name="lazyLoadingEnabled" value="true"/> <setting name="multipleResultSetsEnabled" value="true"/> <setting name="useColumnLabel" value="true"/> <setting name="useGeneratedKeys" value="false"/> <setting name="autoMappingBehavior" value="PARTIAL"/> <setting name="autoMappingUnknownColumnBehavior" value="WARNING"/> <setting name="defaultExecutorType" value="SIMPLE"/> <setting name="defaultStatementTimeout" value="25"/> <setting name="defaultFetchSize" value="100"/> <setting name="safeRowBoundsEnabled" value="false"/> <setting name="mapUnderscoreToCamelCase" value="false"/> <setting name="localCacheScope" value="SESSION"/> <setting name="jdbcTypeForNull" value="OTHER"/> <setting name="lazyLoadTriggerMethods" value="equals,clone,hashCode,toString"/> </settings>
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java 商戶PC端接入支付寶支付的實(shí)現(xiàn)方法
這篇文章主要介紹了java 商戶PC端接入支付寶支付的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
springboot 啟動(dòng)時(shí)初始化數(shù)據(jù)庫的步驟
這篇文章主要介紹了springboot 啟動(dòng)時(shí)初始化數(shù)據(jù)庫的步驟,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下2021-01-01
SpringValidation自定義注解及分組校驗(yàn)功能詳解
這篇文章主要介紹了SpringValidation自定義注解及分組校驗(yàn)功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01
idea2023創(chuàng)建JavaWeb教程之右鍵沒有Servlet的問題解決
最近在寫一個(gè)javaweb項(xiàng)目,但是在IDEA中創(chuàng)建好項(xiàng)目后,在搭建結(jié)構(gòu)的時(shí)候創(chuàng)建servlet文件去沒有選項(xiàng),所以這里給大家總結(jié)下,這篇文章主要給大家介紹了關(guān)于idea2023創(chuàng)建JavaWeb教程之右鍵沒有Servlet問題的解決方法,需要的朋友可以參考下2023-10-10
Java中將List列表轉(zhuǎn)換為字符串的三種方法
這篇文章主要介紹了如何在 Java中將List 轉(zhuǎn)換為 String,接下來使用Java 8 Streams Collectors api和String.join()方法將帶有逗號(hào)分隔符或自定義分隔符的集合轉(zhuǎn)換為字符串,需要的朋友可以參考下2025-04-04
Spring IOC源碼剖析_如何整體認(rèn)知Spring體系結(jié)構(gòu)
這篇文章主要介紹了Spring IOC源碼剖析_如何整體認(rèn)知Spring體系結(jié)構(gòu)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
Java聊天室之使用Socket實(shí)現(xiàn)傳遞圖片
這篇文章主要為大家詳細(xì)介紹了Java簡易聊天室之使用Socket實(shí)現(xiàn)傳遞圖片功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以了解一下2022-10-10

