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

SQL2000記錄鎖定判斷

缺席
ken_lin
一般會員


發表:4
回覆:3
積分:1
註冊:2003-05-06

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-02-06 09:57:07 IP:210.243.xxx.xxx 訂閱
使用 Delphi5.0 + SQL2000 ,用 BDE 連資料庫,在程式中用 TQuery 讀取某筆資料後,用 Query1.Edit 來修正資料
當某人(甲)先用 Query1.Edit 編即資料中但尚未寫入前,另一人(乙)也用Query1.Edit 編輯同一筆資料
請問:
乙此人在程式中要如何判定 Query1.Edit 時,該筆資料已被鎖定,不讓此人進行修改

Thank You
blueK
初階會員


發表:19
回覆:62
積分:36
註冊:2004-05-06

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-02-08 19:28:14 IP:203.67.xxx.xxx 未訂閱
前端元件的UpdateMode屬性,三種不同的設定,會引響異動資料的相關性!!!
Stallion
版主


發表:52
回覆:1600
積分:1995
註冊:2004-09-15

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-02-08 21:59:22 IP:211.22.xxx.xxx 未訂閱
我遇過同樣的需求,經查詢MSSQL線上叢書僅提供整批資料錄(RecordSets)的鎖定,如果僅要鎖定一筆資料錄,根據我的作法就是在該資料表中新增一欄Locked型態是Bit的欄位,當讀取至某一筆時,就將那筆資料錄的Locked欄位設定為1,離開那筆資料錄時設定為0,如此在多人的環境下,經過自己寫的程式判斷就可達到記錄鎖定的目的。請參考~
ken_lin
一般會員


發表:4
回覆:3
積分:1
註冊:2003-05-06

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-02-09 21:54:08 IP:59.114.xxx.xxx 訂閱
您好:
謝謝指教,再請問
我用Tquery ,CachedUpdate設成 True,我讀出該筆資料後
Query1.Edit;
Query1.FieldByName('Lock').Asstring := '1'; //我設定 C 型態 1表目前該筆修改
請問是否要先下 Query1.Post再 Query1.Edit 輸入其他欄位
最後作完
Query1.FieldByName('Lock').Asstring := '0';
Query1.Post;
Query1.ApplyUpdates;
Stallion
版主


發表:52
回覆:1600
積分:1995
註冊:2004-09-15

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-02-12 21:15:57 IP:211.22.xxx.xxx 未訂閱
我個人認為在自訂單筆資料錄鎖定時不適合CACHE UPDATE,因為常常為一筆筆抓出來人為修正後再存回去很耗時,那麼其他人不就等半天只能讀而不能寫入?另外在你UPDATE之前,到底鎖定了多少筆資料是不是還要額外記錄起來在寫回去?增加設計上的困難度!
系統時間:2024-05-19 15:36:34
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!