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

DBGrid 轉入資料時,排除重覆欄位資料

答題得分者是:blueK
monkeyhung
一般會員


發表:51
回覆:55
積分:21
註冊:2006-12-16

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-06-19 10:56:13 IP:203.69.xxx.xxx 訂閱
各位大大,我想請教一下~~

就是當我在dbgrid轉入第一筆資料時是沒有問題的,但若我想再轉入第二筆、第三筆.....時,想將特定欄位[ ProrNo]

與先前有轉入到dbgrid內的資料做比對,若有重覆的話,則將不進行轉入動作。

來源資料 >>>轉入>>>>>DBGrid
第一筆
1 A 1 A
2 B 2 B
3 C 3 C
第二筆 4 D >>>>>第二次轉入
1 D 5 E
2 B 6 F
3 E 7 G >>>>>第三次轉入
4 F
第三筆
1 E
2 G
3 A

Stallion
版主


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-06-19 16:08:48 IP:211.22.xxx.xxx 未訂閱
我認為應該先做好資料庫整理的工作:
1.可能的作法是先寫一支小程式,把原先資料庫,經過比對檢查後寫入另一資料庫,這種需求很容易用2個ADOConnection、1個ADOCommand、2個ADOQuery即可達成。
2.完成了資料整理後,其後在輸入新資料至資料庫時以SELECT COUNT(ProrNo) AS Total的敘述先檢查Primary Key欄位,避免資料庫發生錯誤。
請參考!
carstyc
資深會員


發表:16
回覆:254
積分:329
註冊:2003-07-18

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-06-21 13:07:23 IP:59.115.xxx.xxx 訂閱
針對[PRO_NO]那個欄位建立 Primary Key。

然後在Insert 資料的時候,用 try excption 包起來。

這樣就只會新增不重覆的資料進去。

這是偷工減料的作法...僅供參考
ko
資深會員


發表:28
回覆:785
積分:444
註冊:2002-08-14

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-06-21 13:45:29 IP:61.30.xxx.xxx 訂閱
要從DATASET下手用Locate
而不是在DBGRID上做手腳!!

------
======================
昏睡~
不昏睡~
不由昏睡~
blueK
初階會員


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

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-06-22 12:09:43 IP:203.67.xxx.xxx 未訂閱
轉入的時候直接將Grid關連的Table裡面的資料,
有相同的[ ProrNo] 排除掉!

例如:我們轉入會下一段SQL
select * from TableA
where ProrNo not in(select ProrNo from GridTable)
直接用not in排除掉已經選入的單號

參考參考嚕!
系統時間:2024-05-20 14:22:48
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!