springboot配置mybatis和事務管理方式

一、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>
<!--以上內容放在dependencies標簽外,如果你有已經有父標簽,那將以上部分粘貼到父項目中-->
<!-- spring boot 項目啟動必須引入的web依賴,以下內容放在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的數據庫驅動包 -->
<dependency>
    <groupId>com.oracle</groupId>
    <artifactId>ojdbc6</artifactId>
    <version>11.2.0.4.0-atlassian-hosted</version>
</dependency>

這裡主要說一下上邊的數據庫驅動包,oracle和mysql引入不同的依賴,千萬不要忘記。如果忘記引入,會報找不到驅動類異常。 

2.然後,在application.properties 配置文件裡添加如下內容:

##數據庫連接信息
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
##指向實體類的位置
mybatis.type-aliases-package=cloud.user.models.*

上邊以spring.datasource 開頭的內容其實有很多,具體,在application.properties 文件裡輸入後看看能點出的內容就知道瞭。  

springboot默認會把spring.datasource開頭的信息收納,進行DataSource對象的配置,進而進行sqlSessionFactory的配置等相關數據庫連接的配置,所以其他很多人會說寫什麼配置類,那些我感覺沒有必要的。(配置druid需要配一個@Bean)  

當然如果是特別詳細的,而在application.properties文件裡又通過spring.datasource 點不出相關的配置,那可能需要配置類什麼的。

mybatis.mapper-locations 所指向的位置是從src/main/resource開始的,前邊需要加上classpath,它指向的是你的mapper.xml文件放置的位置。 

3.我是mybatis通過數據庫表逆向工程生成的實體類、mapper等,先把項目具體的放置結構貼出來如下:

這裡寫圖片描述

對於上圖的解釋如下:

啟動類必須放在項目中相對其他類的最高處,前邊文章說過,spring boot沒有傳統的spring 項目配置的<bean> 標簽,它掃描bean的方式就是從啟動類依次向下掃描進默認的內置tomcat容器的。

上圖service放置的位置比其實現類放置的位置高,如果有兩個service A和B,實現類裡有Aimpl和Bimpl,如果有Aimpl調用B的情況,有可能會在啟動容器報“a field named ‘B’ not found”貌似這種錯誤,說明容器掃描順序有誤。

這種情況的最好的解決辦法,就應該像我將service放在高處,容器啟動先掃描進service,然後再掃描impl,這樣在實現類掃描的時候就肯定能找到service,也就不會出現這種錯誤瞭。另一種解決辦法是在引入service時多添加一個註解:@Lazy

@Autowired
@Lazy //這樣就會延遲加載,上圖不需要,這裡隻是解釋這註解
LogsUserActiveMapper logsUserActiveMapper;

總之,如果出現調用與被調用關系,一定要記得,被調用者要首先被掃描進spring boot內置容器,也就是被調用者的包位置要放的較高一些(位置至少也待相平)。

4.service實現類上需要加一個@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實現類中加入事務註解,需要此處添加該註解
@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的配置瞭。

二、事務的配置

就是在mybatis的基礎上加上兩個註解

1、需要的註解為@EnableTransactionManagement@Transactional 兩個,它們來自於下邊這個包:

spring-tx.jar

該包其實在前邊配置mybatis引入依賴時,已自動引入,就是下邊這個:

 <!-- Spring Boot Mybatis 依賴 -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.2.0</version>
</dependency>

所以隻要上邊的依賴引入進來,那事務就不需要再引入包瞭, 

2.首先,找到你的service實現類,加上@Transactional 註解,如果你加在類上,那該類所有的方法都會被事務管理,如果你加在方法上,那僅僅該方法符合具體的事務。當然我們一般都是加在方法上。因為隻有增、刪、改才會需要事務。

比如下邊的一個插入數據的方法添加事務:

@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事務管理配置與@Transactional註解使用

3.配置完後,spring boot啟動類必須要開啟事務,而開啟事務用的註解就是@EnableTransactionManagement ,如下:

@SpringBootApplication
@EnableTransactionManagement 
@MapperScan("microservice.qssj.mapper")//必須加這個,不加報錯,如果不加,也可以在每個mapper上添加@Mapper註釋,並且這裡還要多填一個註釋,那個我忘瞭,我一直用這個註解
public class QssjServiceApplication {
    public static void main(String[] args) {
        SpringApplication.run(QssjServiceApplication.class, args);
    }
}

這樣就完成瞭事務的配置。

總結

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: