看板 Database 關於我們 聯絡資訊
※ 引述《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