如何用Group By,Select出各群組的Top 50 Percent |
答題得分者是:cashxin2002
|
tomking
一般會員 發表:9 回覆:7 積分:3 註冊:2003-03-31 發送簡訊給我 |
如題!
如何用一個SQL敘述Select出各群組的Top 50 Percent
若用以下敘述:
Select A.Sub_No,Avg(A.Score) From(Select Top 50 Percent
Sub_No,Score From Student Order By Sub_No,Score DESC) A
Group By A.Sub_No
會篩選出整體Score(分數)的Top 50 Percent 的平均分數
而不是各Sub_No(科目) Score的Top 50 Percent 的平均分數 請各位大大幫幫我 謝謝! 發表人 - tomking 於 2003/09/05 08:47:14
|
sos_admin
版主 發表:121 回覆:697 積分:768 註冊:2003-07-23 發送簡訊給我 |
|
tomking
一般會員 發表:9 回覆:7 積分:3 註冊:2003-03-31 發送簡訊給我 |
|
sos_admin
版主 發表:121 回覆:697 積分:768 註冊:2003-07-23 發送簡訊給我 |
|
cashxin2002
版主 發表:231 回覆:2555 積分:1937 註冊:2003-03-28 發送簡訊給我 |
您好! 小弟在看您的問題時, 發現有一個另類的問題:
您的Student資料表中, Sub_No(科目)欄位的值應該會有重复吧, 所以您才使用Group By方法加以群組, 那如果是建立群組的話, SQL語句前半段的Select Top 50 Percent Score就會有問題喔, 因為SQL語句從后面的Sub_No的群組來抓前面的Score值, 會出現不知該取何值的現象喔. 您的問題似乎有些混淆, 描述得清楚一些好嗎? 小弟淺見, 誠懇指正! 參考看看! =====================
努力,相信會獲得美麗!
忻晟
------
忻晟 |
tomking
一般會員 發表:9 回覆:7 積分:3 註冊:2003-03-31 發送簡訊給我 |
|
cashxin2002
版主 發表:231 回覆:2555 積分:1937 註冊:2003-03-28 發送簡訊給我 |
|
tomking
一般會員 發表:9 回覆:7 積分:3 註冊:2003-03-31 發送簡訊給我 |
|
cashxin2002
版主 發表:231 回覆:2555 積分:1937 註冊:2003-03-28 發送簡訊給我 |
您好﹗ 你的需要是篩選出每個科目中分數排名前50%(也就是前面一半)的平均分數嗎﹖
如果排名在前50%條件不考慮的話﹐您所寫的就可以﹕
Select A.Sub_No,Avg(A.Score) From(Select Top 50 Percent
Sub_No,Score From Student Order By Sub_No,Score DESC) A
Group By A.Sub_No 但如果要考慮上排名在前50%﹐單個科目分別做篩選﹐也是可以﹐只需要加上Where條件式﹕
Select A.Sub_No,Avg(A.Score) From(Select Top 50 Percent Sub_No,Score From Student Where Sub_No='XXX' Order By Sub_No,Score DESC) A Group By A.Sub_No 但如果需要各個學科一起做篩選的話﹐可能比較困難﹐因為無論是使用In或者是Between...end等方法﹐就變成只篩選Top 50了﹐而丟失了Top 50 Percent的作用﹐所以要看是否有變通的方法逐個的進行篩選﹒ 小弟淺見﹐僅供參考﹗ =====================
努力,相信會獲得美麗!
忻晟
------
忻晟 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |