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

子查詢..我那裡下錯了???

答題得分者是:st33chen
lovemari
中階會員


發表:134
回覆:224
積分:76
註冊:2005-08-18

發送簡訊給我
#1 引用回覆 回覆 發表時間:2009-03-20 10:11:09 IP:122.116.xxx.xxx 訂閱
小弟狀況是有兩各 TALBE
TALBE A資料有
work_order , wo_create_time
TABLE B資料有
work_order , seral_number , rec_time
小弟想寫各
select
a.work_order , count (b.serial_number)
但是必須 a.wo_create_time > b.rec_time 的這種serial_number
才要算在count裡面
可小弟寫下列算式怎樣算都不會管有沒有時間上的差異
通通都被算進來了
想請問是那裡需要改嗎??
[code delphi]
select a.work_order "工單",f.count "不良數量"

from sajet.g_wo_base a,
sajet.g_sn_defect b,
(select count(distinct e.serial_number) count,d.work_order
from sajet.g_wo_base d,
sajet.g_sn_defect e
where d.work_order = e.work_order
and d.wo_create_date > e.rec_time
group by d.work_order ) f
where a.work_order = b.work_order( )
and a.work_order = f.work_order
group by a.work_order,f.count

[/code]
------
Program : Delphi 7
DataBase : Oracle 9i
Client : ClientDataSet
st33chen
尊榮會員


發表:15
回覆:591
積分:1201
註冊:2005-09-30

發送簡訊給我
#2 引用回覆 回覆 發表時間:2009-03-20 13:21:40 IP:122.116.xxx.xxx 未訂閱
您好,

您有試過您 post 上來的 sql statement 中的

select count(distinct e.serial_number) count, d.work_order <--- 避免用 count, 改用 cnt 比較沒有疑慮
from sajet.g_wo_base d, sajet.g_sn_defect e
where d.work_order = e.work_order
and d.wo_create_date > e.rec_time
group by d.work_order

的這一段嗎?

我覺得(因為沒實測)應該就是您要的答案了
------
IS IT WHAT IT IS
我是 李慕白 請倒著唸.
又想把老話拿出來說, 請用台語發音 : 專家專家全是ROBOT CAR (滷肉腳啦);
都已接手這麼久了, 績效還是那麼爛, 講話還那麼大聲.
編輯記錄
st33chen 重新編輯於 2009-03-20 13:23:58, 註解 無‧
lovemari
中階會員


發表:134
回覆:224
積分:76
註冊:2005-08-18

發送簡訊給我
#3 引用回覆 回覆 發表時間:2009-03-20 15:56:15 IP:122.116.xxx.xxx 訂閱
 結果還是一樣耶

還是會不顧 wo_create_time 有沒有 > rec_time

通通算進去了
------
Program : Delphi 7
DataBase : Oracle 9i
Client : ClientDataSet
st33chen
尊榮會員


發表:15
回覆:591
積分:1201
註冊:2005-09-30

發送簡訊給我
#4 引用回覆 回覆 發表時間:2009-03-20 21:00:32 IP:122.116.xxx.xxx 未訂閱
不可能, 害我動手實測, 如下

資料

work_order wo_create_time
--------------- ----------------------
a 5
b 25
c 55

work_order serial_number rec_time
--------------- --------------------- ------------
a 1 4
a 2 5
a 3 6
a 4 7
b 1 20
b 2 21
b 3 23
b 4 24
b 5 25
b 6 26
c 1 55
c 2 56
c 3 57

命令

select a.work_order, count(b.serial_number) cnt
from g_wo_base a, g_sn_defect b
where a.work_order=b.work_order
and a.wo_create_time > b.rec_time
group by a.work_order

結果
work_order cnt
--------------- ---------
a 1
b 4


不知道您的資料是什麼, 那麼奇特

===================引 用 lovemari 文 章===================
結果還是一樣耶

還是會不顧 wo_create_time 有沒有 > rec_time

通通算進去了
------
IS IT WHAT IT IS
我是 李慕白 請倒著唸.
又想把老話拿出來說, 請用台語發音 : 專家專家全是ROBOT CAR (滷肉腳啦);
都已接手這麼久了, 績效還是那麼爛, 講話還那麼大聲.
lovemari
中階會員


發表:134
回覆:224
積分:76
註冊:2005-08-18

發送簡訊給我
#5 引用回覆 回覆 發表時間:2009-03-23 11:13:52 IP:122.116.xxx.xxx 訂閱
沒事了= =

是我自己誤判

我自己找的 WORK_ORDER 例子

剛好所有序號的REC_TIME 都 < WO_CREATE_DATE

而且我發現我不是要 < 我應該是要> = =

難怪我怎麼算都算進去

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