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

在access db裡如何用類似substring查詢

尚未結案
NILSAN
一般會員


發表:5
回覆:11
積分:3
註冊:2003-11-18

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-11-24 21:23:51 IP:203.204.xxx.xxx 未訂閱
各位先進.高手您好:(可否幫幫忙~先謝了) 最近想做資料的比對(程式:DELPHI).. database:access data: tableA之欄位有品號.工時 | tableB之欄位有品號.工時 -------------------------------------------------- 3100012351 23.1 | 210001325 20.1 3100014251 10.1 | 210001456 13.1 3100017895 9.2 | 210001781 18.2 3100021254 12.1 | 210002124 12.1 3100023457 8.1 | 210002122 8.2 -------------------------------------------------- 目標1:3100012351(工時=23.1) sum(210001xxx.工時=51.4)=74.5 或3100014251(工時=10.1) sum(210001xxx.工時=51.4)=61.5 或3100021254(工時=12.1) sum(210002xxx.工時=20.3)=32.4....以此類推 ------------------------------------------------------ 目標2: 項目 | 總工時 3100012351 | 74.5 3100014251 | 61.5 3100021254 | 32.4 自動比對加總... --------------------------------------------------------- 我之愚見: select tableA.品號 as 項目 , tableA.工時 sum(tableB.工時) from tableA , tableB where (select substring(品號,2,5) from tableA) in (select substring(品號,2,5) from tableB) group by table1.品號 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 以上怪怪的sql語法.且access也不能用substring...懇請各位先進多幫忙.. 多指點迷津...先謝各位大大的瀏覽及指點...thx
cashxin2002
版主


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-11-24 22:18:50 IP:63.84.xxx.xxx 未訂閱
您好!    Access資料庫的SQL語法中雖然沒有SubString, 但其有另一個相同作用的字句, Mid, 使用方法和SubString相同.    參考看看!    ===================== 努力,相信會獲得美麗! 忻晟
------
忻晟
NILSAN
一般會員


發表:5
回覆:11
積分:3
註冊:2003-11-18

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-11-25 21:57:14 IP:203.204.xxx.xxx 未訂閱
您好: 我回去有try try see..不過發現table1的資料比較多筆... 而我也不會下一對多的sql指令...請各位大大幫幫忙.. ----------------------------------------------- 我的想法是先將(1)table2的資料分類..工時統計好後再(2)與table1做加總.. 不過我卡在(2)的部分...希望大大伸援手..thx (1)select mid(nu2,1,6) as 項目 , sum(t1) as 總工時 from tt where mid(nu2,1,6)=mid(nu2,1,6) group by mid(nu2,1,6)--->(1)部分的sql語法 (2)....我不會下....
azurecloud
中階會員


發表:52
回覆:108
積分:92
註冊:2003-09-04

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-11-25 22:22:50 IP:163.13.xxx.xxx 未訂閱
Hi,NILSAN 您好: 請在 access 中搜尋 「萬用字元」,您會發現 * 符號符合任何字元個數,它能在字 元字串中,被當做第一個或最後一個字元使用。而? 符號符合任何單一字母的字元。 對於您的問題,我的建議是:若以品號是 10001 為例    select tableA.品號 as 項目 , tableA.工時+sum(tableB.工時) from tableA , tableB where tableA.品號 in (Select 品號 from tableA where 品號 like '?10001????') and tableB.品號 in (Select 品號 from tableB where 品號 like '?10001???') GROUP BY tableB.工時 紅色部份可解決您比對的問題,另外請記得要用 SUM() 函數時,SQL 後面要 加上 GROUP BY tableB.工時 子句,希望能幫得上忙
Mickey
版主


發表:77
回覆:1882
積分:1390
註冊:2002-12-11

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-11-25 22:51:37 IP:218.32.xxx.xxx 未訂閱
NILSAN 你好 : 這是你要的嗎 ? select A.品號, A.工時 (select sum(B.工時) from TableB B where mid(B.品號,2,5)=mid(A.品號,2,5)) from TableA A
NILSAN
一般會員


發表:5
回覆:11
積分:3
註冊:2003-11-18

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-11-26 21:28:44 IP:203.204.xxx.xxx 未訂閱
感謝兩位大大的支援... 終於解決了我的問題了... 再三感謝你們...也讓我多學習了SQL語法的運用...真謝謝你們.
系統時間:2024-06-27 0:36:46
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!