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

請教兩個ADOQuery的SQL寫法

答題得分者是:supman
marklue
一般會員


發表:33
回覆:55
積分:17
註冊:2005-02-09

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-05-10 10:05:13 IP:203.73.xxx.xxx 未訂閱
請問我用兩個ADOQuery及TDBgrid 資料表1為部門代號clas 資料表2為員工資料pers 點選資TDBgrid1時,則TDBgrid2顯示此部門員工 資料表1部門代號為NO-C 員工資料表的部門代號為CNO-P員工代號為NO-P 則ADOQuery2的SQL我是這麼寫 select * from clas , pers where cno-p = no-c order by no-p 可是卻顯示所有員工資料 請問前輩們要如何修正 謝謝
supman
尊榮會員


發表:29
回覆:770
積分:924
註冊:2002-04-22

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-05-10 10:14:59 IP:61.70.xxx.xxx 未訂閱
您好: 您這樣寫當然會找出全部的員工資料,因為你這樣等於去把所有的在員工資料中的部門編號是等於部門資料庫的部門編號全部找出來,所以也就會將員工資料全部找出來了,改成以下這樣, 當點下DBGrid1(部門資料時),在AdoQuery2的SQL 'select * from pers 'where CNo-p = ''' AdoQuery1.FiledByName('No-c').AsString '''' 'order by no-p ' 發表人 - supman 於 2005/05/10 10:24:42
ko
資深會員


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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-05-10 11:16:16 IP:220.132.xxx.xxx 未訂閱
marklue 你好: 如supman說的就可以了 但是重點是select ... from pers 一個資料表就好了
------
======================
昏睡~
不昏睡~
不由昏睡~
marklue
一般會員


發表:33
回覆:55
積分:17
註冊:2005-02-09

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-05-10 13:32:47 IP:203.73.xxx.xxx 未訂閱
supman前輩 KO前輩 好: 因為SQL我不熟所以測試較久 以下是我測出可以用的方式 'select * from pers ' 'where CNo-p = ''' AdoQuery1.FieldByName('No-c').AsString '''' ' order by no-p ' 感恩!
ko
資深會員


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

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-05-11 09:24:12 IP:220.132.xxx.xxx 未訂閱
marklue 你好: 'select * from pers '+ 'where CNo-p = '+Quotedstr(AdoQuery1.FieldByName('No-c').AsString) ' order by no-p ' 用紅色的部分會更好
------
======================
昏睡~
不昏睡~
不由昏睡~
marklue
一般會員


發表:33
回覆:55
積分:17
註冊:2005-02-09

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-05-11 10:48:11 IP:203.73.xxx.xxx 未訂閱
引言: 'select * from pers ' 'where CNo-p = ' Quotedstr(AdoQuery1.FieldByName('No-c').AsString) ' order by no-p ' 用紅色的部分會更好
KO前輩 您好: 請問這兩種方式有何差別? 還有能否請教您,前一個例子中3個單引號的意義是什麼? 感恩!
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#7 引用回覆 回覆 發表時間:2005-05-11 11:51:51 IP:202.62.xxx.xxx 未訂閱
您好﹗    Quotedstr函數的作用是在字串左右各將一個單引號﹐這種方法和組字串(您所述的方法)作用是相同的﹐之所以ko前輩說使用Quotedstr函數方法比較的原因﹐我想是因這種方法比較容易看懂﹒ 'select * from pers where CNo-p='''+AdoQuery1.FieldByName('No-c').AsString+''' order by no-p'; 以上用各種顏色將分號做區分﹐把顏色相同的前后對應起來﹐這樣就比較容易看了﹒ ================================= 有空來瞅瞅我﹗因為我是您的朋友﹐有您真好﹗ ================================
------
忻晟
marklue
一般會員


發表:33
回覆:55
積分:17
註冊:2005-02-09

發送簡訊給我
#8 引用回覆 回覆 發表時間:2005-05-11 13:29:32 IP:203.73.xxx.xxx 未訂閱
cashxin2002版主您好 謝謝您詳細的解說 感恩!
系統時間:2024-06-28 1:50:28
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!