@Transactional事務幾點注意

這裏面有幾點須要你們留意:
A. 一個功能是否要事務,必須歸入設計、編碼考慮。不能僅僅完成了基本功能就ok。
B. 若是加了事務,必須作好開發環境測試(測試環境也儘可能觸發異常、測試回滾),確保事務生效。
C. 如下列了事務使用過程的注意事項,請你們留意。spring

  1. 不要在接口上聲明@Transactional ,而要在具體類的方法上使用 @Transactional 註解,不然註解可能無效。
  2. 不要圖省事,將@Transactional放置在類級的聲明中,放在類聲明,會使得全部方法都有事務。故@Transactional應該放在方法級別,不須要使用事務的方法,就不要放置事務,好比查詢方法。不然對性能是有影響的。
  3. 使用了@Transactional的方法,對同一個類裏面的方法調用, @Transactional無效。好比有一個類Test,它的一個方法A,A再調用Test本類的方法B(無論B是否public仍是private),但A沒有聲明註解事務,而B有。則外部調用A以後,B的事務是不會起做用的。(常常在這裏出錯)
    因爲內部方法使用this.的方式調用,沒有經過spring管理的bean進行調用,因此沒法經過代理織入的方式實現AOP,解決這個問題能夠經過ApplicationContext獲取bean的方式進行調用。
  4. 使用了@Transactional的方法,只能是public,@Transactional註解的方法都是被外部其餘類調用纔有效,故只能是public。道理和上面的有關聯。故在 protected、private 或者 package-visible 的方法上使用 @Transactional 註解,它也不會報錯,但事務無效。
  5. 通過在ICORE-CLAIM中測試,效果以下: * 拋出受查異常XXXException,事務會回滾。 * 拋出運行時異常NullPointerException,事務會回滾。 * Quartz中,execute直接調用加了@Transactional方法,能夠回滾;間接調用,不會回滾。(即上文3點提到的) * 異步任務中,execute直接調用加了@Transactional方法,能夠回滾;間接調用,不會回滾。(即上文3點提到的) * 在action中加上@Transactional,不會回滾。切記不要在action中加上事務。 * 在service中加上@Transactional,若是是action直接調該方法,會回滾,若是是間接調,不會回滾。(即上文3提到的) * 在service中的private加上@Transactional,事務不會回滾。
相關文章
相關標籤/搜索