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

如何取得存檔前的欄位值?

答題得分者是:Fishman
MichaelChien
一般會員


發表:33
回覆:37
積分:14
註冊:2002-12-27

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-01-09 01:30:58 IP:211.76.xxx.xxx 未訂閱
請問要用什麼方法,可以在【存檔前】取得該欄位所輸入的值? 備註:需在新增(dsInsert)與修改(dsEdit)二種狀態下都取得到!!
huangeider
高階會員


發表:288
回覆:492
積分:231
註冊:2003-02-26

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-01-09 03:23:26 IP:218.172.xxx.xxx 未訂閱
可先宣告一全域變數 textstr:string; 在table或adotable中的beforepost程序中 寫上條件 IF table.datasource.DataSet.STATE=DSINSERT THEN textstr:=dbedit1.text; 「堅持」從洗馬桶做起 Aric
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-01-09 08:26:35 IP:210.65.xxx.xxx 未訂閱
Hi:    你也可以用 Table1.FieldValues['FieldName']; 或 Table1.FieldByName('FieldName').AsString;    來取得該欄位所輸入的值(即使未 POST,TQuery、TClientDataSet 也適用)     -------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman
海星
高階會員


發表:41
回覆:217
積分:106
註冊:2003-01-09

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-01-09 08:45:52 IP:211.74.xxx.xxx 未訂閱
最笨的方法: 直接把這筆記錄內容完整Copy起來. 如果需要後悔復原,再Copy回來就好.. 這樣子你就不用判斷用戶改了哪些欄位了. 如果你太閒,時間太多..那每修改一個欄位,那你就必須記錄是那個欄位 (用 OnChange事件紀錄看用戶修改了哪一欄),還原的方法就一樣了。
solnone
中階會員


發表:2
回覆:97
積分:69
註冊:2003-05-06

發送簡訊給我
#5 引用回覆 回覆 發表時間:2004-01-09 10:23:29 IP:210.68.xxx.xxx 未訂閱
在【存檔前】取得該欄位所輸入的值 FieldByName('Field').Value 在【存檔前】取得該欄位原本(未被改過)的值 FieldByName('Field').OldValue
系統時間:2024-06-18 3:47:45
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!