MySQL數據庫之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 語句會刪除重復的數據。

MySQL UNION 操作符語法格式:

SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions]
UNION [ALL | DISTINCT]
SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions];

參數

  • expression1, expression2, … expression_n: 要檢索的列。
  • tables: 要檢索的數據表。
  • WHERE conditions: 可選, 檢索條件。
  • DISTINCT: 可選,刪除結果集中重復的數據。默認情況下 UNION 操作符已經刪除瞭重復數據,所以 DISTINCT修飾符對結果沒啥影響。
  • ALL: 可選,返回所有結果集,包含重復數據。

案例:查詢工作崗位為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效率更高!

另外,對於表連接來說,如果有恰當的union語句可以操作與之相同的效果,優先使用union操作

union使用註意:

查詢的兩個結果集列數必須相同

在Mysql中列的數據類型可以存在差異,但是在Oracle中則不可以

4.limit查詢

limit用於限制結果集的長度

後面可以存在一個參數或者兩個參數(起始下標,取數據條數)

案例:按照薪資降序取出排名前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之後執行

5.分頁

假設每頁要訪問y條數據,那麼第x頁的數據就是

limit((x-1)*y,y)

以上就是MySQL數據庫之union,limit和子查詢詳解的詳細內容,更多關於MySQL union limit 子查詢的資料請關註WalkonNet其它相關文章!

推薦閱讀: