前一陣貼了乙個關於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的問...