聊聊@Transactional事務注意點,你學會了嗎?
這里面有幾點需要大家留意:
A. 一個功能是否要事務,必須納入設計、編碼考慮。不能僅僅完成了基本功能就ok。
B. 如果加了事務,必須做好開發環境測試(測試環境也盡量觸發異常、測試回滾),確保事務生效。
C. 以下列了事務使用過程的注意事項,請大家留意。
1.不要在接口上聲明@Transactional ,而要在具體類的方法上使用 @Transactional 注解,否則注解可能無效。
2.不要圖省事,將@Transactional放置在類級的聲明中,放在類聲明,會使得所有方法都有事務。故@Transactional應該放在方法級別,不需要使用事務的方法,就不要放置事務,比如查詢方法。否則對性能是有影響的。
3.使用了@Transactional的方法,對同一個類里面的方法調用, @Transactional無效。比如有一個類Test,它的一個方法A,A再調用Test本類的方法B(不管B是否public還是private),但A沒有聲明注解事務,而B有。則外部調用A之后,B的事務是不會起作用的。(經常在這里出錯)
4.使用了@Transactional的方法,只能是public,@Transactional注解的方法都是被外部其他類調用才有效,故只能是public。道理和上面的有關聯。故在 protected、private 或者 package-visible 的方法上使用 @Transactional 注解,它也不會報錯,但事務無效。
5.spring的事務在拋異常的時候會回滾,如果是catch捕獲了,事務無效。可以在catch里面加上throw new RuntimeException();
6.最后有個關鍵的一點:
和鎖同時使用需要注意
由于Spring事務是通過AOP實現的,所以在方法執行之前會有開啟事務,之后會有提交事務邏輯。
而synchronized代碼塊執行是在事務之內執行的,可以推斷在synchronized代碼塊執行完時,事務還未提交,其他線程進入synchronized代碼塊后,讀取的數據不是最新的。
所以必須使synchronized鎖的范圍大于事務控制的范圍,
把synchronized加到Controller層或者大于事務邊界的調用層!