阿寶 Keep Walking......


          JUST DO IT, DO YOUR BEST ! -- 勿在浮沙筑高臺

            BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
            49 Posts :: 6 Stories :: 26 Comments :: 0 Trackbacks
          1. Transaction 分兩種,Local Transaction 和 Global Transaction。
          涉及到一個Connection的Commit,稱為Local Transaction。
          涉及到多個Connection的Commit,稱為Global Transaction。
          樓主提到的是,Global Transaction.

          2. Global Transaction 需要XA接口(包括在JTA里面)的支持。

          import javax.sql.XAConnection;
          import javax.transaction.xa.Xid;
          import javax.transaction.xa.XAResource;
          import javax.transaction.xa.XAException;
          import javax.transaction.Transaction;
          import javax.transaction.TransactionManager;

          其中的
          javax.sql.XAConnection;
          javax.transaction.xa.Xid;
          javax.transaction.xa.XAResource;

          這些XA接口的實現,需要數據庫的JDBC提供。
          數據庫本身要支持XA。數據庫的JDBC也要提供XA的實現。

          Oracle, Sybase, DB2, SQL Server等大型數據庫才支持XA, 支持Global Transaction。
          My SQL 連Local Transaction都支持不好,更別說Global Transation了。

          3. XA需要兩階段提交 -- prepare 和 commit.
          假設有兩個Connection, con1, con2, 大體的過程如下,

          con1 = XAResouce1.getConnection...
          con2 = XAResouce2.getConnection...

          con1 do some thing.
          con2 do some thing.
          after they finish.

          pre1 = XAResouce1.prepare();
          pre2 = XAResouce2.prepare();

          if( both pre1 and pre2 are OK){
          XAResouce1 and 2 commit
          }else {
          XAResouce1 and 2 rollback
          }

          前面有人講了,在XAResouce1 and 2 commit的時候,
          可能XAResouce1 commit() 成功了,XAResouce2 commit()失敗了。
          這時候,會拋出一個 “啟發式異常”。程序可以處理這個異常。比如,XAResouce.recover()之類。
          但一般情況下,還真沒別的辦法,需要數據管理員根據數據操作日志 undo所有的操作,或者恢復數據備份。
          有的數據庫在進行數據操作的時候,會生成一個“反操作”日志。比如,insert 對 delete, 等。

          4. TransactionManager的實現能夠處理多個XAResouce(一個XAResouce list)的情況。
          比如Tyrex。或JBoss等EJB Server的Transaction實現代碼。
          posted on 2006-06-01 11:56 阿寶 閱讀(1869) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 鄂州市| 宜城市| 临高县| 滕州市| 高邮市| 祁东县| 保亭| 肃宁县| 安庆市| 嘉义市| 玛曲县| 奎屯市| 景谷| 通渭县| 滨州市| 西青区| 西华县| 无棣县| 牙克石市| 攀枝花市| 大安市| 海盐县| 瑞安市| 莱州市| 交口县| 南投县| 武功县| 钟祥市| 五寨县| 巴楚县| 肃南| 怀远县| 大理市| 香河县| 金沙县| 延庆县| 合肥市| 新龙县| 五家渠市| 林口县| 荆门市|