1. 程式人生 > >spring boot配置mybatis和事務管理

spring boot配置mybatis和事務管理

生成 很多 -s 順序 south 位置 ron 技術 username

spring boot配置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

??上邊以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等,先把項目具體的放置結構貼出來如下:

技術分享圖片

對於上圖的解釋如下:

  1. 啟動類必須放在項目中相對其他類的最高處,前邊文章說過,spring boot沒有傳統的spring 項目配置的<bean> 標簽,它掃描bean的方式就是從啟動類依次向下掃描進默認的內置tomcat容器的。
  2. 上圖service放置的位置比其實現類放置的位置高,如果有兩個service A和B,實現類裏有Aimpl和Bimpl,如果有Aimpl調用B的情況,有可能會在啟動容器報“a field named ‘B’ not found”貌似這種錯誤,說明容器掃描順序有誤。
  3. 這種情況的最好的解決辦法,就應該像我將service放在高處,容器啟動先掃描進service,然後再掃描impl,這樣在實現類掃描的時候就肯定能找到service,也就不會出現這種錯誤了。
  4. 另一種解決辦法是在引入service時多添加一個註解:@Lazy
    @Autowired
    @Lazy //這樣就會延遲加載,上圖不需要,這裏只是解釋這註解
    LogsUserActiveMapper logsUserActiveMapper;
  5. 總之,如果出現調用與被調用關系,一定要記得,被調用者要首先被掃描進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);
    }
}

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

下一篇寫spring boot + druid配置。

spring boot配置mybatis和事務管理