全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1320
推到 Plurk!
推到 Facebook!

計算TDBGrid內所有資料的筆數及CurrentRow

尚未結案
nullx
一般會員


發表:3
回覆:8
積分:2
註冊:2002-07-22

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-04-26 13:59:12 IP:211.73.xxx.xxx 未訂閱
小弟有個TDBGrid的問題,請前輩們指教 : 1) 環境 : Delphi 5 SQL2000 2) 問題 : a)要知道TDBGrid現在總共多少筆資料[n Pages] 因為透過TQuery.recordcount不能正確表示,原因是當 insert row時TQuery.recordcount並不會增加 <若是新增模式下,資料庫本就沒有資料,所以不能以 TQuery.recordcount來代表TDBGrid的筆數> b)判斷目前正在輸入的欄位值在其他Rows是否已經有過相同的值, 若有時則全註記起來,並且停在發生相同的值欄位上 以上兩個問題請前輩們知道如何處理的請不吝賜教 發表人 - nullx 於 2004/04/26 15:57:36
------
蔡俊德
change.jian
版主


發表:29
回覆:620
積分:439
註冊:2003-06-02

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-04-26 15:39:26 IP:61.222.xxx.xxx 未訂閱
1.關於不能取得目前TQuery.recordcount,請參考http://delphi.ktop.com.tw/topic.php?TOPIC_ID=48262 您可以check一下TQuery在沒有移到最後一筆前,recordcount是否為-1,就可知道是否是上面討論中的原因. 2.至於所加入的資料是否重覆,其實您可以用Locate方法就可以得知使用者所加入的資料是否重覆.但如果您的系統是不只一個user輸入的話,就不建議您這樣做了,因為即使USER_A用Locate找不到相同的資料存在TQuery裡,並不表示該筆資料就真的不在資料庫裡.有可能這時有另一個使用者USER_B已先輸入了一筆相同的資料.這時在USER_A裡是沒有這筆資料到,但後端的SQL2000卻已存在該筆資料,這時USER_A再新增一筆,一樣會出現錯誤訊息.建議您直接以try-except-end去包住新增,修改,刪除等動作,當有錯誤時,直接將DB回傳的錯誤訊息轉成使用者可以看得懂訊息,系統設計起來會比較簡單
系統時間:2024-05-15 21:42:25
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!