1. 程式人生 > >【mysql】關於子查詢的一個例子

【mysql】關於子查詢的一個例子

假設表my_tbl包含三個欄位a,b,c;現在需要查詢表中列a的每個不同值下的列b為最小值的記錄量。 比如表記錄為: a  b  c 1  3  'cd' 2  3  'nhd' 1  5  'bg' 2  6  'cds' 1  7  'kiy' 3  7  'vsd' 3  8  'ndf' 希望得到結果為: a  b  c 1  3  'cd' 2  3  'nhd' 3  7  'vsd' (1) 其中一個做法:先查出每個a值下的b最小值,然後根據這些最小值去查詢符合要求的所有記錄。 查詢符合最小b值的sql寫法如下: select A.* from my_tbl as A where A.b=(select min(b) from my_tbl as B where B.a=A.a);
由於是巢狀查詢和取交集,80萬條記錄情況下竟然用一個小時也沒把中間結果算出來(我真懷疑是自己哪裡寫錯了);後面求記錄量就免談了。 (2) 上面的方法是個災難, 只能棄用了。 具體邏輯為:先按列a,b分組,然後選擇每組中列b值最小的記錄,生成結果集。 sql語句寫法如下: select a,b,c,count(a) from (select a,b,c from my_tbl group by a,b) as A group by a; 執行查詢後,時間竟只用了1.1秒。 再一次證明,sql的查詢策略的不同能直接導致效能上的巨大差異。