在使用SpringMvc的時候,配置文件中咱們常常看到 annotation-driven 這樣的註解,其含義就是支持註解,通常根據前綴 tx、mvc 等也能很直白的理解出來分別的做用。tx:annotation-driven/ 就是支持事務註解的(@Transactional) 、http://www.javashuo.com/tag/mvc:annotation-driven 就是支持mvc註解的,說白了就是使Controller中可使用MVC的各類註解。html
首先,<tx:annotation-driven/> 會有一個屬性來指定使用哪一個事務管理器,如:<tx:annotation-driven transaction-manager="transactionManager" />。而後事務管理器 transactionManager 會引用 dataSource (若是咱們使用JPA或Hibernate,也須要指定一個 entityManagerFactory ),dataSouce 確定就是直接對數據庫的了。 這樣逐層引用下去,因此咱們使用@Transactionl 註解能夠控制事務就通俗易懂了。另外要提一下的就是 spring 是使用 aop 經過 asm 操做java字節碼的方式來實現對方法的先後事務管理的。 說到這裏,已經有了對 <tx:annotation-driven/> 的簡單理解,那咱們是否就能夠在程序中全部被spring管理的類上均可以使用@Transactional註解了呢,在Service上可使用[@Transactional](https://my.oschina.net/u/3770144) 註解這個是確定的了,那總有些人也想弄明白可否在Controller 使用?答案顯然是「不必定」的(與時間配置有關),下面作下解釋:
在 spring-framework-reference.pdf 文檔上有這樣一段話:java
tx:annotation-driven/ only looks for @Transactional on beans in the same application context it is defined in. This means that, if you put tx:annotation-driven/ in a WebApplicationContext for a DispatcherServlet, it only checks for @Transactional beans in your controllers, and not your services.spring
意思就是:tx:annoation-driven/只會查找和它在相同的應用上下文件中定義的bean上面的@Transactional註解,若是你把它放在Dispatcher的應用上下文中,它只檢查控制器(Controller)上的@Transactional註解,而不是你services上的@Transactional註解。數據庫
因此,能夠肯定的是咱們是能夠在Controller上使用事務註解的,可是咱們不推薦這樣作(本人也歷來沒有這樣作過),這裏只是爲了說明spring對<tx:annotation-driven/>的使用。
通常的配置方法是讓Spring管理除了Controller註解之外註解,而讓SpringMVC單純管理Controller註解。 也就是說Spring有一個配置文件,裏面配置成掃描非Controller的bean,SpringMVC有一個配置文件,裏面只掃描Controller。 這樣就造成了兩個上下文,即Spring的上下文和SpringMVC的上下文,他們分別管理着不一樣的倆堆bean。mvc
這個時候你在Spring的配置文件里加了一句tx:annoation-driven,實際上是告訴Spring,你管理的這些bean裏面有可能會出現須要事務支持的。 而後在Spring管理範圍的某個bean上加了個註解@transactional,實際上是用來幫助Spring識別這個bean是須要事務管理的。app
一樣你在Spring的配置文件里加了tx:annoation-driven,SpringMVC是不關心的,他只關心你給他配置了什麼以及他管理的bean上有什麼註解spa