SpringBoot集成Mybatis并測(cè)試
首先我們先新建一個(gè)項(xiàng)目,需要選擇以下依賴:


1、SpringBoot鏈接druid連接池
1、在pom文件中加入druid連接池場(chǎng)景啟動(dòng)器,如下所示:
<!-- druid 場(chǎng)景啟動(dòng)器 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.2.3</version>
</dependency>2、在全局配置類(lèi)中添加以下配置:
spring:
# application:
# name: dev-manager
datasource:
# 配置數(shù)據(jù)源類(lèi)型
type:
com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/springboot_mybatis?useUnicode=true&characterEncoding=UTF-8
username: root
password: root
# 初始化,最小,最大連接數(shù)
initialSize: 3
minidle: 3
maxActive: 18
# 獲取數(shù)據(jù)庫(kù)連接等待的超時(shí)時(shí)間
maxWait: 60000
# 配置多久進(jìn)行一次檢測(cè),檢測(cè)需要關(guān)閉的空閑連接 單位毫秒
timeBetweenEvictionRunsMillis: 60000
validationQuery: SELECT 1 FROM dual
# 配置監(jiān)控統(tǒng)計(jì)攔截的filters,去掉后,監(jiān)控界面的sql無(wú)法統(tǒng)計(jì)
# filters: stat,wall,log4j
# 初始化時(shí)運(yùn)行sql腳本
schema: classpath:sql/schema.sql
initialization-mode: always
druid:
stat-view-servlet:
enabled: true3、這個(gè)時(shí)候druid的數(shù)據(jù)鏈接其實(shí)是已經(jīng)鏈接上了,下來(lái)我們可以配置一些druid的監(jiān)控,先分析一下,在自動(dòng)配置類(lèi)中引入的DruidStatViewServletConfiguration就是監(jiān)控的,可以生成一個(gè)監(jiān)控界面。
@Configuration
@ConditionalOnClass({DruidDataSource.class})
@AutoConfigureBefore({DataSourceAutoConfiguration.class})
@EnableConfigurationProperties({DruidStatProperties.class, DataSourceProperties.class})
// DruidStatViewServletConfiguration 是配置監(jiān)控的類(lèi)
@Import({DruidSpringAopConfiguration.class, DruidStatViewServletConfiguration.class, DruidWebStatFilterConfiguration.class, DruidFilterConfiguration.class})
public class DruidDataSourceAutoConfigure {
}4、當(dāng)我們點(diǎn)擊進(jìn)入DruidStatViewServletConfiguration 類(lèi)的時(shí)候,會(huì)發(fā)現(xiàn)當(dāng)我們?cè)谌峙渲梦募袥](méi)有配置spring.datasource.druid.stat-view-servlet.enabled配置的時(shí)候,這個(gè)類(lèi)將不生效,監(jiān)控界面也就無(wú)法起來(lái),代碼如下:
@ConditionalOnWebApplication
@ConditionalOnProperty(
name = {"spring.datasource.druid.stat-view-servlet.enabled"},
havingValue = "true"
)
public class DruidStatViewServletConfiguration {
}5、我們先不要在全局配置里面配置上面的屬性,進(jìn)入地址 http://localhost:8080/druid/login.html ,就會(huì)打不開(kāi),如下所示:

6、下面我們?cè)谌峙渲梦募信渲昧诉@個(gè)配置之后,然后再打開(kāi)監(jiān)控的網(wǎng)站頁(yè)面,如下所示:
spring:
datasource:
druid:
stat-view-servlet:
enabled: true
7、依據(jù)于DruidStatViewServletConfiguration類(lèi)的下面代碼,我們就可以類(lèi)似的加一些其它的配置,就比如登錄名密碼什么的,代碼如下:
application.yml配置
druid:
stat-view-servlet:
enabled: true
login-username: root
login-password: 1232、SpringBoot集成Mybatis
2.1、引入Mybatis-generator
1、在pom文件中引入mybatis-generator插件,代碼如下所示:
<!-- Mybatis-Generator插件,自動(dòng)生成代碼 -->
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.2</version>
<configuration>
<configurationFile>${project.basedir}/src/main/resources/generatorConfig.xml</configurationFile>
<overwrite>true</overwrite>
<verbose>true</verbose>
</configuration>
<dependencies>
<!-- 必須要引入數(shù)據(jù)庫(kù)驅(qū)動(dòng) -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<!-- 必須要指定相應(yīng)的版本 -->
<version>8.0.22</version>
</dependency>
</dependencies>
</plugin>2、加入上面引入的generatorConfig.xml文件,代碼示例如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<!--數(shù)據(jù)庫(kù)驅(qū)動(dòng)
使用dos命令時(shí),需要配置數(shù)據(jù)庫(kù)驅(qū)動(dòng)
-->
<!--<classPathEntry location="D:\Java\apache-maven-3.5.4\repository\mysql\mysql-connector-java\8.0.15\mysql-connector-java-8.0.15.jar"/>-->
<!-- context配置上下文,配置生成規(guī)則
id 任意寫(xiě)
MyBatis3DynamicSql 默認(rèn)的,會(huì)生成帶動(dòng)態(tài)sql的CRUD
MyBatis3 生成通用的查詢,可以指定動(dòng)態(tài)where的條件
MyBatis3Simple 只生成簡(jiǎn)單的CRUD
<context id="context" targetRuntime="MyBatis3Simple">
<!-- 注釋生成器 -->
<!--<commentGenerator>
<property name="suppressDate" value="true"/>
<property name="suppressAllComments" value="true"/>
</commentGenerator>-->
<!--數(shù)據(jù)庫(kù)鏈接地址賬號(hào)密碼-->
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/springboot_mybatis?serverTimezone=UTC"
userId="root"
password="root">
</jdbcConnection>
<javaTypeResolver>
<!--<property name="forceBigDecimals" value="false"/>-->
</javaTypeResolver>
<!--生成Model類(lèi)存放位置
targetPackage 生成到哪個(gè)包下
targetProject 生成到當(dāng)前文件的哪個(gè)對(duì)應(yīng)路徑下
<javaModelGenerator targetPackage="cool.ale.pojo" targetProject="src/main/java">
<!--<property name="enableSubPackages" value="true"/>
<property name="trimStrings" value="true"/>-->
</javaModelGenerator>
<!--生成映射文件存放位置
<sqlMapGenerator targetPackage="cool.ale.mapper" targetProject="src/main/resources">
<!--<property name="enableSubPackages" value="true"/>-->
</sqlMapGenerator>
<!--生成Dao類(lèi)存放位置
type 指定生成的方式
1、使用注解的方式生成
2、使用接口綁定的方式生成(一定要配置sqlMapGenerator)
<javaClientGenerator type="XMLMAPPER" targetPackage="cool.ale.mapper" targetProject="src/main/java">
</javaClientGenerator>
<!--生成對(duì)應(yīng)表及類(lèi)名
domainObjectName 對(duì)應(yīng)的實(shí)體類(lèi)的名字
mapperName 對(duì)應(yīng)的mapper接口以及mapper.xml文件的名字-->
<table tableName="emp" domainObjectName="Emp"></table>
<table tableName="dept" domainObjectName="Dept"></table>
</context>
</generatorConfiguration>3、找到maven中這個(gè)插件,雙擊運(yùn)行

2.2、集成mybatis并測(cè)試
1、在pom文件中引入mybatis和mysql的依賴,代碼如下所示:
<!-- mybatis連接池,是mybatis自己提供 -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.2.0</version>
</dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>2、在全局配置文件里面配置mapper-location的路徑,指定mapper.xml文件在哪
# 設(shè)置mybatis的mapper-location mybatis: mapper-locations: classpath:cool/ale/mapper/*Mapper.xml
3、在SpringBoot啟動(dòng)類(lèi)的地方指定mapper接口的路徑,如下所示:
@MapperScan("cool.ale.mapper")
public class SpringbootMybatisApplication {
public static void main(String[] args) {
SpringApplication.run(SpringbootMybatisApplication.class, args);
}
}4、寫(xiě)一個(gè)controller來(lái)測(cè)試剛才生成的CRUD代碼:
package cool.ale.controller;
import cool.ale.mapper.EmpMapper;
import cool.ale.pojo.Emp;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
@RequestMapping("/emp")
public class EmpController {
@Autowired
private EmpMapper empMapper;
@RequestMapping("/all")
public List<Emp> selectAll(){
return empMapper.selectAll();
}
}5、成功截圖如下:

3、其它
3.1、自定義druid鏈接池
1、在pom文件中加入依賴:
<!-- 缺少 druid 連接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.3</version>
</dependency>2、全局配置里面配置:
spring:
# application:
# name: dev-manager
datasource:
# 配置數(shù)據(jù)源類(lèi)型
type:
com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/springboot_mybatis?useUnicode=true&characterEncoding=UTF-8
username: root
password: root
# 初始化,最小,最大連接數(shù)
initialSize: 3
minidle: 3
maxActive: 18
# 獲取數(shù)據(jù)庫(kù)連接等待的超時(shí)時(shí)間
maxWait: 60000
# 配置多久進(jìn)行一次檢測(cè),檢測(cè)需要關(guān)閉的空閑連接 單位毫秒
timeBetweenEvictionRunsMillis: 60000
validationQuery: SELECT 1 FROM dual
# 配置監(jiān)控統(tǒng)計(jì)攔截的filters,去掉后,監(jiān)控界面的sql無(wú)法統(tǒng)計(jì)
# filters: stat,wall,log4j
# 初始化時(shí)運(yùn)行sql腳本
schema: classpath:sql/schema.sql
initialization-mode: always3、書(shū)寫(xiě)配置類(lèi),其實(shí)和剛才我們進(jìn)入jar包寫(xiě)的方法差不多,代碼如下:
package cool.ale.config;
import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import javax.sql.DataSource;
@Configuration
// 當(dāng)我們的全局配置文件配置了 spring.datasource.type 屬性時(shí),這個(gè)類(lèi)才生效
@ConditionalOnProperty("spring.datasource.type")
public class DruidConfiguration {
@Bean
// 會(huì)綁定 application.yml 所有的 spring.datasource 開(kāi)頭的配置綁定到 DataSource
@ConfigurationProperties("spring.datasource")
public DataSource dataSource(){
return new DruidDataSource();
}
/*// 第二種辦法
public DataSource dataSource(DataSourceProperties properties){
// 根據(jù)配置動(dòng)態(tài)創(chuàng)建一個(gè) DataSource
return properties.initializeDataSourceBuilder().build();
}*/
/**
* 監(jiān)控臺(tái)的 servlet
*/
public ServletRegistrationBean statViewServlet() {
ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean();
servletRegistrationBean.setServlet(new StatViewServlet());
// 設(shè)置了這個(gè)屬性之后,我們就可以通過(guò) druid 地址去訪問(wèn) druid 的一個(gè)監(jiān)控臺(tái)
// 比如:http://localhost:8080/druid/login.html
servletRegistrationBean.addUrlMappings("/druid/*");
// 添加IP白名單
servletRegistrationBean.addInitParameter("allow","127.0.0.1");
// 添加IP黑名單,當(dāng)白名單和黑名單重復(fù)時(shí),黑名單優(yōu)先級(jí)更高
servletRegistrationBean.addInitParameter("deny","127.0.0.1");
// 添加控制臺(tái)管理用戶
servletRegistrationBean.addInitParameter("loginUsername","admin");
servletRegistrationBean.addInitParameter("loginPassword","123456");
// 是否能夠重置數(shù)據(jù)
servletRegistrationBean.addInitParameter("resetEnable","false");
return servletRegistrationBean;
* 配置服務(wù)過(guò)濾器:監(jiān)控哪些訪問(wèn)
*
* @return 返回過(guò)濾器的配置對(duì)象
public FilterRegistrationBean statFilter() {
FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());
// 添加過(guò)濾器規(guī)則,所有的請(qǐng)求都會(huì)被攔截
filterRegistrationBean.addUrlPatterns("/*");
// 忽略過(guò)濾格式
filterRegistrationBean.addInitParameter("exclusions","*.js,*.gif,*.jpg,/druid/*");
return filterRegistrationBean;
}3.2、SpringBoot的Mybatis其它配置
@Bean
@ConditionalOnMissingBean
public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception {
SqlSessionFactoryBean factory = new SqlSessionFactoryBean();
factory.setDataSource(dataSource);
factory.setVfs(SpringBootVFS.class);
// 設(shè)置Mybatis的全局配置文件
if (StringUtils.hasText(this.properties.getConfigLocation())) {
factory.setConfigLocation(this.resourceLoader.getResource(this.properties.getConfigLocation()));
}
// 有另一種定制方法的體現(xiàn)
// 里面有一些關(guān)于mybatis全局配置文件的setting的實(shí)現(xiàn)
this.applyConfiguration(factory);
if (this.properties.getConfigurationProperties() != null) {
factory.setConfigurationProperties(this.properties.getConfigurationProperties());
// Mybatis的插件攔截器,
// 我們只需要實(shí)現(xiàn)了一個(gè)Interceptor接口的攔截器注入到IOC容器中,就可以起作用
if (!ObjectUtils.isEmpty(this.interceptors)) {
factory.setPlugins(this.interceptors);
// 設(shè)置數(shù)據(jù)庫(kù)廠商ID
if (this.databaseIdProvider != null) {
factory.setDatabaseIdProvider(this.databaseIdProvider);
// 去application.yml去找typeAliasesPackage屬性,設(shè)置別名使用
if (StringUtils.hasLength(this.properties.getTypeAliasesPackage())) {
factory.setTypeAliasesPackage(this.properties.getTypeAliasesPackage());
// 根據(jù)父類(lèi)給子類(lèi)設(shè)置別名
// 去application.yml找aliasesSuperType屬性
if (this.properties.getTypeAliasesSuperType() != null) {
factory.setTypeAliasesSuperType(this.properties.getTypeAliasesSuperType());
// 通過(guò)包設(shè)置類(lèi)型處理器
if (StringUtils.hasLength(this.properties.getTypeHandlersPackage())) {
factory.setTypeHandlersPackage(this.properties.getTypeHandlersPackage());
// 通過(guò)類(lèi)設(shè)置類(lèi)型處理器
if (!ObjectUtils.isEmpty(this.typeHandlers)) {
factory.setTypeHandlers(this.typeHandlers);
// 設(shè)置mapper-location
if (!ObjectUtils.isEmpty(this.properties.resolveMapperLocations())) {
factory.setMapperLocations(this.properties.resolveMapperLocations());
Set<String> factoryPropertyNames = (Set)Stream.of((new BeanWrapperImpl(SqlSessionFactoryBean.class)).getPropertyDescriptors()).map(FeatureDescriptor::getName).collect(Collectors.toSet());
Class<? extends LanguageDriver> defaultLanguageDriver = this.properties.getDefaultScriptingLanguageDriver();
if (factoryPropertyNames.contains("scriptingLanguageDrivers") && !ObjectUtils.isEmpty(this.languageDrivers)) {
factory.setScriptingLanguageDrivers(this.languageDrivers);
if (defaultLanguageDriver == null && this.languageDrivers.length == 1) {
defaultLanguageDriver = this.languageDrivers[0].getClass();
}
if (factoryPropertyNames.contains("defaultScriptingLanguageDriver")) {
factory.setDefaultScriptingLanguageDriver(defaultLanguageDriver);
return factory.getObject();
}注意:但是上面的applyConfiguration方法點(diǎn)開(kāi)之后我們會(huì)發(fā)現(xiàn)一個(gè)問(wèn)題,要想定制Mybatis的全局配置中的settings,只有下面兩種方法。
1、直接在SpringBoot的全局配置文件里面指定Mybatis的全局配置文件
2、在SpringBoot的全局配置文件配置configuration + 實(shí)現(xiàn)這個(gè)ConfigurationCustomizer類(lèi)
private void applyConfiguration(SqlSessionFactoryBean factory) {
org.apache.ibatis.session.Configuration configuration = this.properties.getConfiguration();
// 當(dāng)沒(méi)有配置configuration 但是指定了mybatis的全局配置文件
if (configuration == null && !StringUtils.hasText(this.properties.getConfigLocation())) {
configuration = new org.apache.ibatis.session.Configuration();
}
// 當(dāng)配置了configuration 并且實(shí)現(xiàn)了ConfigurationCustomizer類(lèi)
if (configuration != null && !CollectionUtils.isEmpty(this.configurationCustomizers)) {
Iterator var3 = this.configurationCustomizers.iterator();
while(var3.hasNext()) {
ConfigurationCustomizer customizer = (ConfigurationCustomizer)var3.next();
customizer.customize(configuration);
}
factory.setConfiguration(configuration);
}到此這篇關(guān)于SpringBoot集成Mybatis并測(cè)試的文章就介紹到這了,更多相關(guān)SpringBoot集成Mybatis內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解SpringBoot如何優(yōu)雅的進(jìn)行全局異常處理
在SpringBoot的開(kāi)發(fā)中,為了提高程序運(yùn)行的魯棒性,我們經(jīng)常需要對(duì)各種程序異常進(jìn)行處理,但是如果在每個(gè)出異常的地方進(jìn)行單獨(dú)處理的話,這會(huì)引入大量業(yè)務(wù)不相關(guān)的異常處理代碼,這篇文章帶大家了解一下如何優(yōu)雅的進(jìn)行全局異常處理2023-07-07
簡(jiǎn)單易懂的Java Map數(shù)據(jù)添加指南
Java提供了多種方法來(lái)往Map中添加數(shù)據(jù),開(kāi)發(fā)者可以根據(jù)具體需求選擇合適的方法,需要的朋友可以參考下2023-11-11
idea maven項(xiàng)目無(wú)法識(shí)別jar包里的class解決方案
這篇文章主要介紹了idea maven項(xiàng)目無(wú)法識(shí)別jar包里的class解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06
Java 基礎(chǔ)面試真題:String 為什么是不可變的?
本文主要介紹了String、StringBuffer和StringBuilder的區(qū)別,以及String不可變的原因,String不可變的原因是其內(nèi)部使用final修飾的char數(shù)組保存字符串,同時(shí)String類(lèi)沒(méi)有提供修改字符串的方法,在Java9之后,String的底層實(shí)現(xiàn)由char[]改成了byte[],這是為了節(jié)省內(nèi)存空間2025-01-01
解決Mybatis-plus和pagehelper依賴沖突的方法示例
這篇文章主要介紹了解決Mybatis-plus和pagehelper依賴沖突的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
Java 基礎(chǔ)之內(nèi)部類(lèi)詳解及實(shí)例
這篇文章主要介紹了 Java 基礎(chǔ)之內(nèi)部類(lèi)詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-03-03

