《Mysql必讀MySQL子查詢用法實例分析》要點:
本文介紹了Mysql必讀MySQL子查詢用法實例分析,希望對您有用。如果有疑問,可以聯系我們。
本文實例講述了MySQL子查詢用法.分享給大家供大家參考,具體如下:MYSQL應用
假設表my_tbl包含三個字段a,b,c;現在需要查詢表中列a的每個不同值下的列b為最小值的記錄量.MYSQL應用
比如表記錄為:MYSQL應用
a? b? c
1? 3? 'cd'
2? 3? 'nhd'
1? 5? 'bg'
2? 6? 'cds'
1? 7? 'kiy'
3? 7? 'vsd'
3? 8? 'ndf'MYSQL應用
希望得到結果為:MYSQL應用
a? b? c
1? 3? 'cd'
2? 3? 'nhd'
3? 7? 'vsd'MYSQL應用
(1) 其中一個做法:先查出每個a值下的b最小值,然后根據這些最小值去查詢符合要求的所有記錄.MYSQL應用
查詢符合最小b值的sql寫法如下:
MYSQL應用
由于是嵌套查詢和取交集,80萬條記錄情況下竟然用一個小時也沒把中間結果算出來(我真懷疑是自己哪里寫錯了);后面求記錄量就免談了.MYSQL應用
(2) 上面的辦法是個災難, 只能棄用了.MYSQL應用
具體邏輯為:先按列a,b分組,然后選擇每組中列b值最小的記錄,生成結果集.MYSQL應用
sql語句寫法如下:
MYSQL應用
執行查詢后,時間竟只用了1.1秒.MYSQL應用
再一次證明,sql的查詢策略的不同能直接導致性能上的巨大差異.MYSQL應用
更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數據庫鎖相關技巧匯總》及《MySQL常用函數大匯總》MYSQL應用
希望本文所述對大家MySQL數據庫計有所贊助.MYSQL應用
歡迎參與《Mysql必讀MySQL子查詢用法實例分析》討論,分享您的想法,維易PHP學院為您提供專業教程。