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

用DBGrid進行大批資料的新增或修改﹐怎樣判定主鍵重復?

尚未結案
dialog
一般會員


發表:33
回覆:18
積分:10
註冊:2002-09-07

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-07-21 19:49:33 IP:218.18.xxx.xxx 未訂閱
table1 (F1,F2,F3,F4)其中F1 F2為Key, AdoDataset1.LockType:=ltBatchOptimistic 用DBGrid進行大批資料的新增或修改﹐在修改(或新增)F1和F2時﹐怎樣判定主鍵重復?
timhuang
尊榮會員


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-07-21 20:43:31 IP:61.62.xxx.xxx 未訂閱
可以在新增或是異動前先進行一次檢查, 如 select * from TABLE WHERE f1='xxx' and f2='xxx' 若是沒有資料的話, 再進行新增或是異動. 另一個方式就是直接去異動, 利用 database 回傳的錯誤訊息來處理, 也就是在新增或是異動時用 try ... except 來進行 error handle 即可, 利用 database 會檢查 primary key violation check 來進行程式也是一種方式!
dialog
一般會員


發表:33
回覆:18
積分:10
註冊:2002-09-07

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-07-22 12:49:04 IP:218.18.xxx.xxx 未訂閱
請注意﹐AdoDataset1.LockType:=ltBatchOptimistic, 如果第一筆記錄為F1='aaa',F2='bbb',用select * from TABLE WHERE f1='aaa' and f2='bbb'查不到資料﹐可能新增﹐但是在下一筆又輸入F1='aaa',F2='bbb'﹐又檢測不到﹐ 如果用Primary Key 來檢驗的話﹐在大量的資料時﹐不能定位是哪一筆記錄重復﹐這不是我想要的。
系統時間:2024-06-19 0:15:03
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!