一、瞭解事務源
我在面試中經常會問到這樣的一個問題,假如有一個全域變數,在一個事務中修改了這個變數的值,而後這個事務因為別的原因復原了,那這個變數的值會復原到更改之前的值麼?
其實事務只能對它所管理的資源進行提交和復原,這些資源就是事務源,它通常包括資料庫連接資源,JMS隊列資源等。事務的ACID(原子性,一致性,隔離性,持久性)屬性也是針對它所管理的資源而言的。前面問題中的一個全域變數,可以說是記憶體中的一Block Storage空間,那麼記憶體中的資料如何能具備事務屬性中的持久性呢?很顯然它不在事務的管轄範圍之內,也就不會跟著事務的復原而復原了。
二、何時復原事務
在JDBC事務和EJB的Bean管理事務中,我們通常會按下面這種方式控制事務的復原。在出現某種的異常情況下,我們可以控制讓交易回復,當然也可以提交這個事務。
Connection cn = ...
cn.setAutoCommit(false);
Statement stmt = cn.createStatement();
try{
stmt.executeUpdate("update Order...");
cn.commit();
}catch(Exception e) {
cn.rollback(); //出現異常,復原當前事務
}finally{
stmt.close();
cn.close();
}
但是對於EJB的容器管理事務或者Spring的聲明式事務,就不大一樣了。例如:
Connection cn = ...
cn.setAutoCommit(false);
Statement stmt = cn.createStatement();
try{
stmt.executeUpdate("update Order...");
cn.commit();
}catch(Exception e) {
cn.rollback(); //出現異常,復原當前事務
}finally{
stmt.close();
cn.close();
}