線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:828
推到 Plurk!
推到 Facebook!

在ADODataset中,如何做Dirty Write?

尚未結案
SimonLee
一般會員


發表:15
回覆:23
積分:7
註冊:2003-09-20

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-09-25 07:18:03 IP:61.144.xxx.xxx 未訂閱
在ADODataset中,如何做Dirty Write? 例如,ADODataset是設定用BatchOptimistic,有二個用戶分別讀了 同一條記錄,其一個用戶更新了記錄,另一個用戶想用Dirty Write 的方法,將他的修改Overwrite之前用戶的修改。 資料庫是用MS SQL。
hahalin
版主


發表:295
回覆:1698
積分:823
註冊:2002-04-14

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-09-25 09:28:57 IP:210.243.xxx.xxx 未訂閱
check the locktype...
SimonLee
一般會員


發表:15
回覆:23
積分:7
註冊:2003-09-20

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-09-25 11:52:59 IP:218.17.xxx.xxx 未訂閱
可否清楚一點解釋一下,因為我已經試過, 另外我的ADODataset是正在打開的,改這個 屬性是否有問題呢?
SimonLee
一般會員


發表:15
回覆:23
積分:7
註冊:2003-09-20

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-09-25 11:58:42 IP:218.17.xxx.xxx 未訂閱
LockType應該是不可以的,因為我的系統是Client/Server的, LockType一定是要ltBatchOptimistic。
SimonLee
一般會員


發表:15
回覆:23
積分:7
註冊:2003-09-20

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-09-28 07:30:36 IP:218.17.xxx.xxx 未訂閱
我已經找到答案了 procedure TForm1.Button2Click(Sender: TObject); var ii: integer; ff: boolean; oo: integer; begin ff := false; ii := 0; while (ii <= ADODataset1. Recordset. Properties. Count - 1) and not ff do if ADODataset1. Recordset. Properties. Item[ii]. Name = 'Update Criteria' then begin oo := ADODataset1. Recordset. Properties. Item[ii]. Value; ADODataset1. Recordset. Properties. Item[ii]. Value := 0; break; end else ii := ii 1; ADODataSet1. UpdateBatch; ADODataset1. Recordset. Properties. Item[ii]. Value := oo; end; end.
系統時間:2024-06-26 7:55:57
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!