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。
推薦閱讀:
- Spring Boot 整合 TKMybatis 二次簡化持久層代碼的實現
- springboot多模塊化整合mybatis,mapper自動註入失敗問題及解決
- SpringBoot實現ORM操作MySQL的幾種方法
- 一篇超詳細的Spring Boot整合Mybatis文章
- Easycode自動化springboot的curd