TransactionScope的正確用法

2021-08-22 05:37:31 字數 755 閱讀 8040

前一陣貼了乙個關於transactionscope的貼子,以為是ms的bug。後來經過認真仔細的除錯,才找到原因。

原來的**本身是沒有沒問題的。只是關於事務資源的處理放錯了地方。正確的寫法應該如下

如果a類是使用資料庫資源的。

class a

sqlconnection cn=null;

public a()

cn.open();

//開始事務

using(transactionscope scope=new transactionscope())

//要確保對支援事務的資源的登記放在此範圍內,如資料庫資源的開啟

a a=new a();

a.method();

scope.comlete()

我們只要確保資料庫的開啟操作是在事務範圍內開啟就行了。這樣就可以做到事務的正確操作。

以前的**是因為乙個業務物件的初始化操作在外部進行了。儘管後來在事務範圍內進行業務操作,也不行.

a a=new a();

using(transactionscope scope=new transactionscope())

//要確保對支援事務的資源的登記放在此範圍內,如資料庫資源的開啟

a.method();

scope.comlete()

上述**,其實是沒有參與任何事務的。對於子事務而已也是一樣,只要保證事務登記在事務範圍內才正確

我是檢視了資料庫中開啟連線的情況才知道上面的原理。真是慚愧的很.

TransactionScope的正確用法

前一陣貼了乙個關於transactionscope的貼子,以為是ms的bug。後來經過認真仔細的除錯,才找到原因。原來的 本身是沒有沒問題的。只是關於事務資源的處理放錯了地方。正確的寫法應該如下 如果a類是使用資料庫資源的。class a sqlconnection cn null public a...

TransactionScope的正確用法

前一陣貼了乙個關於transactionscope的貼子,以為是ms的bug。後來經過認真仔細的除錯,才找到原因。原來的 本身是沒有沒問題的。只是關於事務資源的處理放錯了地方。正確的寫法應該如下 如果a類是使用資料庫資源的。class a sqlconnection cn null public a...

strncpy和snprintf的正確用法詳解

copyleft by bitfly permalink 正文 strncpy的正確用法 strncpy dest,src,sizeof dest dest sizeof dest 1 0 snprintf的正確用法 snprintf dest,sizeof dest s src strncpy的問...