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

TDBGrid+TADOQuery

尚未結案
wireless80211g
一般會員


發表:9
回覆:7
積分:3
註冊:2005-10-22

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-11-16 02:52:50 IP:220.142.xxx.xxx 未訂閱
大家好!有一個問題想請教!!我使用的是TDBGrid TADOQuery元件! 我利用TDBGrid TADOQuery抓取資料庫資料時如何讓我的第一個欄位CUST_CODE(會員號碼)照順序排?還有如何讓DBGrid不將重複的會員號碼去除?
MorganBoy
一般會員


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-11-16 06:02:23 IP:61.231.xxx.xxx 未訂閱
由 TAdoQuery的SQL內容著手。 select distinct ... from yourtable order by cust_code TDBGrid的項目清單及次序由雙點TDBGrid以編修Column Editor為之
christie
資深會員


發表:30
回覆:299
積分:475
註冊:2005-03-25

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-11-16 15:35:54 IP:61.59.xxx.xxx 未訂閱
1.select * from table_name order by cust_code 2.一般而言DBGrid不會“去除”你重複的data. 有問題再上來問. 發表人 -
------
What do we live for if not to make life less difficult for each other?
wireless80211g
一般會員


發表:9
回覆:7
積分:3
註冊:2005-10-22

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-11-16 23:05:27 IP:220.142.xxx.xxx 未訂閱
關於第二項的程式碼 procedure TfrmSupplier.FormShow(Sender: TObject); begin //設定SupplierGrid讀取Supplier資料表 With dma.quSupplier do Begin SQL.Clear; SQL.Add('Select * from Supplier'); Close; Open; End end; 讓quSupplier抓到的資料SHOW在DBGrid上,可是他卻會把重複的編號去除,真的很奇怪,一樣的方法用在抓取其他資料的編號都不會有自動將重複的編號去除的問題!!還是說DBGrid或Query的屬性有哪些是要注意的??幫幫我吧 謝!
christie
資深會員


發表:30
回覆:299
積分:475
註冊:2005-03-25

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-11-17 13:22:07 IP:203.73.xxx.xxx 未訂閱
1.請註明使用的資料庫及其版本! 2.如果Supplier資料表的PrimaryKey是CUST_CODE(會員號碼)便不允許重複的值。
------
What do we live for if not to make life less difficult for each other?
wireless80211g
一般會員


發表:9
回覆:7
積分:3
註冊:2005-10-22

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-11-17 21:24:59 IP:220.142.xxx.xxx 未訂閱
資料庫版本 MS SQL Server 2000 我在資料庫中並沒有設主索引 奇怪的是我用兩個DBGrid來開啟兩個資料表 但是卻只有開啟這個資料表會自動把重複的編號去除 另一個卻不會(開啟的方法和使用元件都相同)
kgt
高階會員


發表:17
回覆:308
積分:165
註冊:2002-03-13

發送簡訊給我
#7 引用回覆 回覆 發表時間:2005-11-18 12:53:46 IP:61.219.xxx.xxx 未訂閱
請問您的基本資料是否有問題,65 years old還在寫程式嗎?
ntjrr
高階會員


發表:240
回覆:312
積分:110
註冊:2005-04-24

發送簡訊給我
#8 引用回覆 回覆 發表時間:2005-11-18 20:50:26 IP:222.184.xxx.xxx 未訂閱
瞎说两句,你试试 好象这个代码有些异样? Begin SQL.Clear; SQL.Add('Select * from Supplier'); Close; Open; End 应该 close排在第一行吧?
------
我的编程起步于ktop,我将永远支持ktop
kgt
高階會員


發表:17
回覆:308
積分:165
註冊:2002-03-13

發送簡訊給我
#9 引用回覆 回覆 發表時間:2005-11-19 07:17:12 IP:61.219.xxx.xxx 未訂閱
關於第二項的程式碼 procedure TfrmSupplier.FormShow(Sender: TObject); begin //設定SupplierGrid讀取Supplier資料表 With dma.quSupplier do Begin SQL.Clear; SQL.Add('Select * from Supplier'); Close; Open; End end; 讓quSupplier抓到的資料SHOW在DBGrid上,可是他卻會把重複的編號去除,真的很奇怪,一樣的方法用在抓取其他資料的編號都不會有自動將重複的編號去除的問題!!還是說DBGrid或Query的屬性有哪些是要注意的??幫幫我吧 謝! ---->請您先用其他非delphi的工具去看一下該Supplier真實的資料為何?
tonytop
中階會員


發表:6
回覆:114
積分:89
註冊:2003-12-04

發送簡訊給我
#10 引用回覆 回覆 發表時間:2005-11-19 18:10:36 IP:203.204.xxx.xxx 未訂閱
一、先用SQL Explorer或access連進資料庫看Supplier裡面的資料是否有重複,若確定cust_code這欄位不能重複,建議設為「主索引」來避免重複,且資料量大時搜尋也會快些。 二、若不想管資料庫,那就用sql解決吧!請看以下範例,建議close在前面。
 
  with ADOQuery1 do
  begin
    Close;
    SQL.Clear;
    SQL.Add('Select distinct(cust_code) from Supplier');
    Open;
  end;
<[忙盲茫]> ☆俺要升級啊☆
系統時間:2024-06-16 17:19:43
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!