MySQL數(shù)據(jù)庫之union,limit和子查詢詳解
1.where中的子查詢
案例:查詢比最低工資高的員工姓名和薪資
子查詢,先查詢子查詢括號里的,再向上級進行查詢
mysql> select ename,sal from emp where sal -> > -> (select min(sal) from emp); +--------+---------+ | ename | sal | +--------+---------+ | ALLEN | 1600.00 | | WARD | 1250.00 | | JONES | 2975.00 | | MARTIN | 1250.00 | | BLAKE | 2850.00 | | CLARK | 2450.00 | | SCOTT | 3000.00 | | KING | 5000.00 | | TURNER | 1500.00 | | ADAMS | 1100.00 | | JAMES | 950.00 | | FORD | 3000.00 | | MILLER | 1300.00 | +--------+---------+ 13 rows in set (0.02 sec)
2.from子句后的子查詢
from后面的子查詢,可以將子查詢的查詢結果當作一張臨時表來看待
案例:找出每個崗位的平均薪資的薪資等級
mysql> select -> t.*,s.grade -> from -> (select job,avg(sal) as avgsal from emp group by job) t -> join salgrade s -> on -> t.avgsal between s.losal and s.hisal; +-----------+-------------+-------+ | job | avgsal | grade | +-----------+-------------+-------+ | CLERK | 1037.500000 | 1 | | SALESMAN | 1400.000000 | 2 | | MANAGER | 2758.333333 | 4 | | ANALYST | 3000.000000 | 4 | | PRESIDENT | 5000.000000 | 5 | +-----------+-------------+-------+ 5 rows in set (0.00 sec)
3.union
MySQL UNION 操作符用于連接兩個以上的 SELECT 語句的結果組合到一個結果集合中。多個 SELECT 語句會刪除重復的數(shù)據(jù)。
MySQL UNION 操作符語法格式:
SELECT expression1, expression2, ... expression_n FROM tables [WHERE conditions] UNION [ALL | DISTINCT] SELECT expression1, expression2, ... expression_n FROM tables [WHERE conditions];
參數(shù)
- expression1, expression2, ... expression_n: 要檢索的列。
- tables: 要檢索的數(shù)據(jù)表。
- WHERE conditions: 可選, 檢索條件。
- DISTINCT: 可選,刪除結果集中重復的數(shù)據(jù)。默認情況下 UNION 操作符已經(jīng)刪除了重復數(shù)據(jù),所以 DISTINCT修飾符對結果沒啥影響。
- ALL: 可選,返回所有結果集,包含重復數(shù)據(jù)。
案例:查詢工作崗位為MANAGER或者SALESMAN的員工信息(使用union)
mysql> select ename,job from emp where job = 'MANAGER' -> union -> select ename,job from emp where job = 'SALESMAN'; +--------+----------+ | ename | job | +--------+----------+ | JONES | MANAGER | | BLAKE | MANAGER | | CLARK | MANAGER | | ALLEN | SALESMAN | | WARD | SALESMAN | | MARTIN | SALESMAN | | TURNER | SALESMAN | +--------+----------+ 7 rows in set (0.00 sec)
為什么使用union而不是or邏輯運算?因為union效率更高!
另外,對于表連接來說,如果有恰當?shù)膗nion語句可以操作與之相同的效果,優(yōu)先使用union操作
union使用注意:
查詢的兩個結果集列數(shù)必須相同
在Mysql中列的數(shù)據(jù)類型可以存在差異,但是在Oracle中則不可以
4.limit查詢
limit用于限制結果集的長度
后面可以存在一個參數(shù)或者兩個參數(shù)(起始下標,取數(shù)據(jù)條數(shù))
案例:按照薪資降序取出排名前5的員工信息
mysql> select ename,sal -> from emp -> order by sal desc -> limit 0,5; +-------+---------+ | ename | sal | +-------+---------+ | KING | 5000.00 | | FORD | 3000.00 | | SCOTT | 3000.00 | | JONES | 2975.00 | | BLAKE | 2850.00 | +-------+---------+ 5 rows in set (0.00 sec)
limit在order by之后執(zhí)行
5.分頁
假設每頁要訪問y條數(shù)據(jù),那么第x頁的數(shù)據(jù)就是
limit((x-1)*y,y)
以上就是MySQL數(shù)據(jù)庫之union,limit和子查詢詳解的詳細內容,更多關于MySQL union limit 子查詢的資料請關注腳本之家其它相關文章!
相關文章
修改MySQL數(shù)據(jù)庫中表和表中字段的編碼方式的方法
這篇文章主要介紹了如何修改MySQL數(shù)據(jù)庫中表和表中字段的編碼方式,需要的朋友可以參考下2014-05-05MySQL中union和join語句使用區(qū)別的辨析教程
這篇文章主要介紹了MySQL中union和join語句的用法區(qū)別,舉例說明了union和join在連接操作上的不同作用,需要的朋友可以參考下2015-12-12