mysql 關於子查詢的乙個例子

2021-09-06 10:39:48 字數 911 閱讀 2222

假設表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 關於子查詢的乙個例子

假設表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 ...

乙個例子講述OracleAny子查詢

問題 查詢出emp表中比任意乙個銷售員 salesman 工資低的員工姓名 工作 工資。分析 銷售員在emp表中有很多條記錄,每個人工資不相等,如果返回 比任意員工的工資還低 的條件,返回比 最高工資還低 即可。如果用子查詢做,子查詢中就會返回多條記錄。用普通的關係符 等 執行就會出錯。這時候需要用...

mysql 多表連線查詢的乙個例子

現在有三個表 角色表 shop role id role name 許可權表 shop privilege id pri name 角色許可權表 shop role pri role id pri id 要查詢角色所擁有的許可權名稱。思路 先查詢角色擁有的許可權 id 在角色許可權表 再通過許可權 ...