作者lisyu (游小蝦)
看板Database
標題Re: [SQL ] 子查詢和count的問題
時間Tue Nov 23 11:26:30 2010
※ 引述《suexin (幸福)》之銘言:
: 大家好,
: 不好意思,想請教大家ㄧ些問題
: 下面是建在資料庫中的表格
: chin (table名稱) 而且有三個欄位
: __________________________
: name area subarea
: 1 USA NY
: 2 TW TAI
: 3 USA NY
: 4 JP TKO
: 5 JP TKO
: 6 TW NAN
: 7 TW NAN
: 8 USA LA
: 9 USA LA
: 10 JP OO
: ___________________________
: 以下是想要查詢出來的表格
: _____________________________________________________
: name area subarea numarea numsubarea ratio
: _____________________________________________________
: 1 USA NY 4 2 0.5
: 2 USA NY 4 2 0.5
: 3 USA LA 4 2 0.5
: 4 USA LA 4 2 0.5
: 5 TW TAI 3 1 0.33
: 6 TW NAN 3 2 0.66
: 7 TW NAN 3 2 0.66
: 8 JP TKO 3 2 0.66
: 9 JP TKO 3 2 0.66
: 10 JP OO 3 1 0.33
: ______________________________________________________
: 我想要對area去做分群
: 再對subarea 又做一次分群
: 然後計算出 area中各個資料的個數
: 再算出 subarea佔原本area的比例。
: numarea就是不同area的資料個數
: 舉個例子:
: USA就有4筆資料,然後USA又有兩個子項目
: 而NY就佔USA中的2筆,所以numsubarea為2
: 然後再算出ratio
: ratio就是 2/4 = 0.5
: 嘗試過用group by area,但是只能對area做分群而且算出個數而已
: 且無法留下完整的10筆資料
: 所以想請問大家要如何將10筆資料都留著
: 還要更進一步算出ratio
: 我想了很久一直無法解決
: 如果要解決 是不是ㄧ定要用到子查詢呢?
: 因為剛接觸mysql不久,
: 所以對子查詢一點頭緒也沒有,
: 請大家幫忙 謝謝。
其實子查詢並不難
就把它當作一個獨立查詢看
然後再用欄位關連起來就好
因為我沒有mysql
所以下面用的是MSSQL的寫法
應該是不會差太多
SELECT chin.name, chin.area, chin.subarea, area.numarea,subarea.numsubarea
,ROUND(CAST(subarea.numsubarea AS float) / CAST(area.numarea AS float), 2)
AS ratio
FROM chin INNER JOIN
(SELECT COUNT(*) AS numarea, area
FROM chin AS chin_1
GROUP BY area) AS area ON chin.area = area.area INNER JOIN
(SELECT COUNT(*) AS numsubarea, subarea
FROM chin AS chin_2
GROUP BY subarea) AS subarea ON chin.subarea = subarea.subarea
ORDER BY chin.area, chin.subarea
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 125.227.22.102
推 suexin:非常謝謝你的幫忙...我大概知道要怎麼做了!!真的很謝謝你 11/26 01:05
推 mathrew:剛好遇到相同問題, 感謝 04/13 16:52