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

ADO/BatchUpdate模式如何判斷資料有異動

答題得分者是:RobertLi
MorganBoy
一般會員


發表:14
回覆:75
積分:22
註冊:2003-04-30

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-12-01 22:54:05 IP:61.231.xxx.xxx 未訂閱
各位前輩,小弟用Ado/LockType[ltBatchOptimistic]以啟動批次更新的功能。小弟有一問題:如何判斷有資料被異動過? 如果是改了某筆資料及尚未離開此筆後進行下列查核是可以判斷出 1.AdoQuery1.Modified為True 2.AdoQuery1.State為dsEdit 但如果離開此筆則這兩個方法就不靈了。這當然不行,因為可能User已改了N筆資料,如果User又沒有按『存檔』而我又沒法偵測出來有異動而讓修改的資料丟光光,我會被客戶殺頭的。
RobertLi
一般會員


發表:1
回覆:31
積分:21
註冊:2002-09-01

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-12-01 23:08:17 IP:61.231.xxx.xxx 未訂閱
試試: function TForm1.IsModified : Boolean ; var FilteredYes : Boolean ; ThisGroup : TFilterGroup ; begin FilteredYes := AdoQuery1.Filtered ; ThisGroup := AdoQuery1.FilterGroup ; AdoQuery1.DisableControls ; AdoQuery1.Filtered := True ; AdoQuery1.FilterGroup := fgPendingRecords ; // Result := AdoQuery1.RecordCount > 0 ; AdoQuery1.Filtered := FilteredYes ; AdoQuery1.FilterGroup := ThisGroup ; AdoQuery1.EnableControls ; end ;
hahalin
版主


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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-12-01 23:20:15 IP:218.170.xxx.xxx 未訂閱
adoquery1.RowsAffected
hahalin
版主


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

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-12-01 23:25:14 IP:218.170.xxx.xxx 未訂閱
sorry,我剛試了一下,不是你要的答案,抱歉...出糗囉...
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#5 引用回覆 回覆 發表時間:2004-12-02 00:09:12 IP:220.132.xxx.xxx 未訂閱
Hi, 請參考類似討論 http://delphi.ktop.com.tw/topic.php?TOPIC_ID=60243 讀取 UpdateStatus 即可!!
MorganBoy
一般會員


發表:14
回覆:75
積分:22
註冊:2003-04-30

發送簡訊給我
#6 引用回覆 回覆 發表時間:2004-12-02 00:26:23 IP:61.231.xxx.xxx 未訂閱
謝謝 RobertLi、Hahalin、timhuang三位前輩的立即回應與幫忙,小弟萬分感激。 小弟試用 RobertLi 前輩的碼已將問題解決了。謝謝前輩。 因為User在作業時會在不同Record中異動及移動,並非均在同一筆Record時完成所有作業,所以RecordStatus對我來說也是不行的﹝當然我可以將AdoQuery全部掃瞄一次,那是可以的,但可能在資料多時會有點費時﹞。我有時是要在FormCloseQuery時作檢查﹝此時全是批次更新﹞,有時要對某些會改到PK的欄位時﹝此時要立即寫到後端及檢查後端﹞。 再次謝謝三位前輩的幫忙,小弟銘感五內。
系統時間:2024-05-19 0:56:04
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!