這里面有幾點需要大家留意:
A. 一個功能是否要事務,必須納入設計回官、編碼考慮曹宴。不能僅僅完成了基本功能就ok。
B. 如果加了事務歉提,必須做好開發(fā)環(huán)境測試(測試環(huán)境也盡量觸發(fā)異常笛坦、測試回滾),確保事務生效苔巨。
C. 以下列了事務使用過程的注意事項版扩,請大家留意。
- 不要在接口上聲明@Transactional 侄泽,而要在具體類的方法上使用 @Transactional 注解礁芦,否則注解可能無效。
2.不要圖省事悼尾,將@Transactional放置在類級的聲明中柿扣,放在類聲明,會使得所有方法都有事務闺魏。故@Transactional應該放在方法級別窄刘,不需要使用事務的方法,就不要放置事務舷胜,比如查詢方法娩践。否則對性能是有影響的活翩。
3.使用了@Transactional的方法,對同一個類里面的方法調用翻伺, @Transactional無效材泄。比如有一個類Test,它的一個方法A吨岭,A再調用Test本類的方法B(不管B是否public還是private)拉宗,但A沒有聲明注解事務,而B有辣辫。則外部調用A之后旦事,B的事務是不會起作用的。(經(jīng)常在這里出錯)
4.使用了@Transactional的方法急灭,只能是public姐浮,@Transactional注解的方法都是被外部其他類調用才有效,故只能是public葬馋。道理和上面的有關聯(lián)卖鲤。故在 protected、private 或者 package-visible 的方法上使用 @Transactional 注解畴嘶,它也不會報錯蛋逾,但事務無效。
5.經(jīng)過在ICORE-CLAIM中測試窗悯,效果如下:
A.拋出受查異常XXXException区匣,事務會回滾。
B.拋出運行時異常NullPointerException蒋院,事務會回滾亏钩。
C.Quartz中,execute直接調用加了@Transactional方法悦污,可以回滾铸屉;間接調用,不會回滾切端。(即上文3點提到的)
D.異步任務中彻坛,execute直接調用加了@Transactional方法,可以回滾踏枣;間接調用昌屉,不會回滾。(即上文3點提到的)
E.在action中加上@Transactional茵瀑,不會回滾间驮。切記不要在action中加上事務。
F.在service中加上@Transactional马昨,如果是action直接調該方法竞帽,會回滾扛施,如果是間接調,不會回滾屹篓。(即上文3提到的)
G.在service中的private加上@Transactional疙渣,事務不會回滾。