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

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數據庫計有所贊助。

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