MySQL数据库之union,limit和子查询详解

2022-07-25 10:48:27
目录
1.where中的子查询2.from子句后的子查询3.union4.limit查询5.分页

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>

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 子查询的资料请关注易采站长站其它相关文章!