本文實(shí)例講述了MySQL子查詢用法。分享給大家供大家參考,具體如下:
假設(shè)表my_tbl包含三個(gè)字段a,b,c;現(xiàn)在需要查詢表中列a的每個(gè)不同值下的列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'
希望得到結(jié)果為:
a b c
1 3 'cd'
2 3 'nhd'
3 7 'vsd'
(1) 其中一個(gè)做法:先查出每個(gè)a值下的b最小值,然后根據(jù)這些最小值去查詢符合要求的所有記錄。
查詢符合最小b值的sql寫法如下:
由于是嵌套查詢和取交集,80萬條記錄情況下竟然用一個(gè)小時(shí)也沒把中間結(jié)果算出來(我真懷疑是自己哪里寫錯(cuò)了);后面求記錄量就免談了。
(2) 上面的方法是個(gè)災(zāi)難, 只能棄用了。
具體邏輯為:先按列a,b分組,然后選擇每組中列b值最小的記錄,生成結(jié)果集。
sql語句寫法如下:
執(zhí)行查詢后,時(shí)間竟只用了1.1秒。
再一次證明,sql的查詢策略的不同能直接導(dǎo)致性能上的巨大差異。