程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> MySQL子查詢用法實例分析

MySQL子查詢用法實例分析

編輯:關於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的查詢策略的不同能直接導致性能上的巨大差異。

更多關於MySQL相關內容感興趣的讀者可查看本站專題:《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數據庫鎖相關技巧匯總》及《MySQL常用函數大匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved