Spring中Transactional配置
@Transactional(noRollbackFor=RuntimeException.class)方法事務說明
@Transactional(RollbackFor=Exception.class)
@Transactional(readOnly=true)
@Transactional(timeout=100)
@Transactional(isolation)資料庫的隔離級別
{
Read Uncommited:讀取未提交的資料(會出現髒讀不可重複讀 幻讀)
Read Commited:讀已提交的資料(會出現不可重複讀和幻讀)
Repeatable Read:可重複讀(會出現幻讀)
Serializable:序列化
}
髒讀:一個事務讀取到另外一個事務未提交的更新的資料
不可重複讀:在同一事務中,多次讀取同一個資料返回結果有所不同,就是後續的讀取可以讀到另外一個事務的已經的已經提交的更新資料
可重複讀:在同一個事務多次讀取資料時,能夠保證所讀取的資料一樣,也就是後讀取的不能讀到另外一個事務已經提交的資料
幻讀:一個事務讀取到另外一個事務已經提交的更新的資料
針對查詢方法
@Transactional(propagation=Propagation.NOT_SUPPORTED)針對某個方法不開啟事務
@Transactional(propagation=Propagation.REQUIRED)預設的事務支援
例子:
public class Bean1 {
@Transactional(propagation=Propagation.Required)
public void update() {
executeUpdate(SQL);
}
}
public class Bean2 {
@Transactional(propagation=Propagation.SUPPORTS)
public void update() {
executeUpdate(SQL);
}
}
public class Transaction {
@Transactional(propagation=Propagation.REQUIRES_NEW)
public void test1()
{
bean1.update();
bean2.update();
}
@Transactional(propagation=Propagation.NOT_SUPPORTED)
public void test2()
{
bean1.update();
bean2.update();
}
@Transactional(propagation=Propagation.SUPPORTS)
public void test3()
{
bean1.update();
bean2.update();
}
}
//事務傳播屬性
@Transactional(propagation=Propagation.REQUIRED)//如果有事務,那麼加入事務,沒有的話新建立一個
@Transactional(propagation=Propagation.NOT_SUPPORTED)//這個方法不開啟事務
@Transactional(propagation=Propagation.REQUIREDS_NEW)//不管是否存在事務,都建立一個新的事務,原來的掛起,新的執行完畢,繼續執行老的事務
@Transactional(propagation=Propagation.MANDATORY)//必須在一個已有的事務中執行,否則丟擲異常
@Transactional(propagation=Propagation.NEVER)//不能在一個事務中執行,就是當前必須沒有事務,否則丟擲異常
@Transactional(propagation=Propagation.SUPPORTS)//其他bean呼叫這個方法,如果在其他bean中聲明瞭事務,就是用事務。沒有宣告,就不用事務。
@Transactional(propagation=Propagation.NESTED)//如果一個活動的事務存在,則執行在一個巢狀的事務中,如果沒有活動的事務,則按照REQUIRED屬性執行,它使用一個單獨的事務。這個事務擁有多個回滾的儲存點,內部事務的回滾不會對外部事務造成影響,它只對DataSource TransactionManager事務管理器起效。
@Transactional(propagation=Propagation.REQUIRED,readOnly=true)//只讀,不能更新,刪除
@Transactional(propagation=Propagation.REQUIRED,timeout=30)//超時30秒
@Transactional(propagation=Propagation.REQUIRED,isolation=Isolation.DEFAULT)//資料庫隔離級別
還可以加上:@Transactional(propagation=Propagation.NOT_SUPPORTED,readOnly=true),這樣就做成一個只讀事務,可以提高效率。
各種屬性的意義:
REQUIRED:業務方法需要在一個容器裡執行。如果方法執行時,已經處在一個事務中,那麼加入到這個事務,否則自己新建一個新的事務。
NOT_SUPPORTED:宣告方法不需要事務。如果方法沒有關聯到一個事務,容器不會為他開啟事務,如果方法在一個事務中被呼叫,該事務會被掛起,呼叫結束後,原先的事務會恢復執行。
REQUIRESNEW:不管是否存在事務,該方法總彙為自己發起一個新的事務。如果方法已經執行在一個事務中,則原有事務掛起,新的事務被建立。
MANDATORY:該方法只能在一個已經存在的事務中執行,業務方法不能發起自己的事務。如果在沒有事務的環境下被呼叫,容器丟擲例外。
SUPPORTS:該方法在某個事務範圍內被呼叫,則方法成為該事務的一部分。如果方法在該事務範圍外被呼叫,該方法就在沒有事務的環境下執行。
NEVER:該方法絕對不能在事務範圍內執行。如果在就拋例外。只有該方法沒有關聯到任何事務,才正常執行。
NESTED:如果一個活動的事務存在,則執行在一個巢狀的事務中。如果沒有活動事務,則按REQUIRED屬性執行。它使用了一個單獨的事務,這個事務 擁有多個可以回滾的儲存點。內部事務的回滾不會對外部事務造成影響。它只對DataSourceTransactionManager事務管理器起效。