springboot配置mybatis和事務(wù)管理方式
一、spring boot與mybatis的配置
1.首先,spring boot 配置mybatis需要的全部依賴如下:
<!-- Spring Boot 啟動父依賴 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.1.RELEASE</version>
</parent>
<!--以上內(nèi)容放在dependencies標(biāo)簽外,如果你有已經(jīng)有父標(biāo)簽,那將以上部分粘貼到父項(xiàng)目中-->
<!-- spring boot 項(xiàng)目啟動必須引入的web依賴,以下內(nèi)容放在dependency即可 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>1.5.1.RELEASE</version>
</dependency>
<!-- Spring Boot Mybatis 依賴 -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.2.0</version>
</dependency>
<!-- oracle的數(shù)據(jù)庫驅(qū)動包 -->
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc6</artifactId>
<version>11.2.0.4.0-atlassian-hosted</version>
</dependency>這里主要說一下上邊的數(shù)據(jù)庫驅(qū)動包,oracle和mysql引入不同的依賴,千萬不要忘記。如果忘記引入,會報(bào)找不到驅(qū)動類異常。
2.然后,在application.properties 配置文件里添加如下內(nèi)容:
##數(shù)據(jù)庫連接信息 spring.datasource.url=jdbc:oracle:thin:@//192.168.1.171:1521/orcl spring.datasource.username=znxd spring.datasource.password=znxd spring.datasource.driver-class-name=oracle.jdbc.driver.OracleDriver ##指向mapper的xml文件位置 mybatis.mapper-locations=classpath:mapper/*Mapper.xml ##指向?qū)嶓w類的位置 mybatis.type-aliases-package=cloud.user.models.*
上邊以spring.datasource 開頭的內(nèi)容其實(shí)有很多,具體,在application.properties 文件里輸入后看看能點(diǎn)出的內(nèi)容就知道了。
springboot默認(rèn)會把spring.datasource開頭的信息收納,進(jìn)行DataSource對象的配置,進(jìn)而進(jìn)行sqlSessionFactory的配置等相關(guān)數(shù)據(jù)庫連接的配置,所以其他很多人會說寫什么配置類,那些我感覺沒有必要的。(配置druid需要配一個@Bean)
當(dāng)然如果是特別詳細(xì)的,而在application.properties文件里又通過spring.datasource 點(diǎn)不出相關(guān)的配置,那可能需要配置類什么的。
mybatis.mapper-locations 所指向的位置是從src/main/resource開始的,前邊需要加上classpath,它指向的是你的mapper.xml文件放置的位置。
3.我是mybatis通過數(shù)據(jù)庫表逆向工程生成的實(shí)體類、mapper等,先把項(xiàng)目具體的放置結(jié)構(gòu)貼出來如下:

對于上圖的解釋如下:
啟動類必須放在項(xiàng)目中相對其他類的最高處,前邊文章說過,spring boot沒有傳統(tǒng)的spring 項(xiàng)目配置的<bean> 標(biāo)簽,它掃描bean的方式就是從啟動類依次向下掃描進(jìn)默認(rèn)的內(nèi)置tomcat容器的。
上圖service放置的位置比其實(shí)現(xiàn)類放置的位置高,如果有兩個service A和B,實(shí)現(xiàn)類里有Aimpl和Bimpl,如果有Aimpl調(diào)用B的情況,有可能會在啟動容器報(bào)“a field named ‘B’ not found”貌似這種錯誤,說明容器掃描順序有誤。
這種情況的最好的解決辦法,就應(yīng)該像我將service放在高處,容器啟動先掃描進(jìn)service,然后再掃描impl,這樣在實(shí)現(xiàn)類掃描的時候就肯定能找到service,也就不會出現(xiàn)這種錯誤了。另一種解決辦法是在引入service時多添加一個注解:@Lazy
@Autowired @Lazy //這樣就會延遲加載,上圖不需要,這里只是解釋這注解 LogsUserActiveMapper logsUserActiveMapper;
總之,如果出現(xiàn)調(diào)用與被調(diào)用關(guān)系,一定要記得,被調(diào)用者要首先被掃描進(jìn)spring boot內(nèi)置容器,也就是被調(diào)用者的包位置要放的較高一些(位置至少也待相平)。
4.service實(shí)現(xiàn)類上需要加一個@Service 注解。這個可能不需要,我一直沒有試試。
5.spring boot+mybatis除了這些要求,還需要在啟動類處添加一個注解@MapperScan,如下:
package cloud.kafka;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.transaction.annotation.EnableTransactionManagement;
@SpringBootApplication
@EnableTransactionManagement //如果mybatis中service實(shí)現(xiàn)類中加入事務(wù)注解,需要此處添加該注解
@MapperScan("cloud.kafka.mapper") //掃描的是mapper.xml中namespace指向值的包位置
public class KafkaLogApplication {
public static void main(String[] args){
SpringApplication.run(KafkaLogApplication.class, args);
}
}
如下是我的mapper.xml里namespace的值
<mapper namespace="cloud.kafka.mapper.LogsUserActiveMapper" >
**這樣就完成mybatis的配置了。
二、事務(wù)的配置
就是在mybatis的基礎(chǔ)上加上兩個注解
1、需要的注解為@EnableTransactionManagement 和@Transactional 兩個,它們來自于下邊這個包:
spring-tx.jar
該包其實(shí)在前邊配置mybatis引入依賴時,已自動引入,就是下邊這個:
<!-- Spring Boot Mybatis 依賴 --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.2.0</version> </dependency>
所以只要上邊的依賴引入進(jìn)來,那事務(wù)就不需要再引入包了,
2.首先,找到你的service實(shí)現(xiàn)類,加上@Transactional 注解,如果你加在類上,那該類所有的方法都會被事務(wù)管理,如果你加在方法上,那僅僅該方法符合具體的事務(wù)。當(dāng)然我們一般都是加在方法上。因?yàn)橹挥性觥h、改才會需要事務(wù)。
比如下邊的一個插入數(shù)據(jù)的方法添加事務(wù):
@Override
@Transactional(propagation = Propagation.REQUIRED,isolation = Isolation.DEFAULT,timeout=36000,rollbackFor=Exception.class)
public Integer add(Cbf_jtcy t) {
return cbf_jtcyMapper.insert(t);
}如果不知道里邊都是什么東西,可以查看這篇文章,spring,mybatis事務(wù)管理配置與@Transactional注解使用
3.配置完后,spring boot啟動類必須要開啟事務(wù),而開啟事務(wù)用的注解就是@EnableTransactionManagement ,如下:
@SpringBootApplication
@EnableTransactionManagement
@MapperScan("microservice.qssj.mapper")//必須加這個,不加報(bào)錯,如果不加,也可以在每個mapper上添加@Mapper注釋,并且這里還要多填一個注釋,那個我忘了,我一直用這個注解
public class QssjServiceApplication {
public static void main(String[] args) {
SpringApplication.run(QssjServiceApplication.class, args);
}
}這樣就完成了事務(wù)的配置。
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
JDK10新特性之var泛型和多個接口實(shí)現(xiàn)方法
這篇文章主要介紹了JDK10的新特性:var泛型和多個接口實(shí)現(xiàn)方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05
Java類庫BeanUtils組件使用方法及實(shí)例詳解
這篇文章主要介紹了Java類庫BeanUtils組件使用方法級實(shí)例詳解,需要的朋友可以參考下2020-02-02
解析springboot整合谷歌開源緩存框架Guava Cache原理
本文主要為大家解析了springboot整合谷歌開源緩存框架Guava Cache的原理以及在實(shí)際開發(fā)過程中的使用,附含源碼,有需要的朋友可以參考下2021-08-08
Java實(shí)現(xiàn)讀取及生成Excel文件的方法
這篇文章主要介紹了Java實(shí)現(xiàn)讀取及生成Excel文件的方法,結(jié)合實(shí)例形式分析了java通過引入第三方j(luò)ar包poi-3.0.1-FINAL-20070705.jar實(shí)現(xiàn)針對Excel文件的讀取及生成功能,需要的朋友可以參考下2017-12-12
java連接mysql數(shù)據(jù)庫及測試是否連接成功的方法
這篇文章主要介紹了java連接mysql數(shù)據(jù)庫及測試是否連接成功的方法,結(jié)合完整實(shí)例形式分析了java基于jdbc連接mysql數(shù)據(jù)庫并返回連接狀態(tài)的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-09-09
如何在Redis中實(shí)現(xiàn)分頁排序查詢過程解析
這篇文章主要介紹了如何在Redis中實(shí)現(xiàn)分頁排序查詢過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-07-07
談?wù)凷pring AOP中@Aspect的高級用法示例
在Spring AOP中目前只有執(zhí)行方法這一個連接點(diǎn),下面這篇文章主要給大家介紹了關(guān)于Spring AOP中@Aspect的高級用法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08
Spring容器-BeanFactory和ApplicationContext使用詳解
這篇文章主要為大家介紹了Spring容器-BeanFactory和ApplicationContext的使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04

