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

作者:世界尽头与你 时间:2024-01-16 08:15:29 

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)

来源:https://blog.csdn.net/Gherbirthday0916/article/details/125959596

标签:MySQL,union,limit,子查询
0
投稿

猜你喜欢

  • BP神经网络原理及Python实现代码

    2022-09-04 21:12:24
  • Python3监控疫情的完整代码

    2023-09-24 09:53:19
  • SQL中的开窗函数详解可代替聚合函数使用

    2024-01-20 08:03:24
  • 浅谈MySQL之select优化方案

    2024-01-27 03:32:38
  • SQL汇总统计与GROUP BY过滤查询实现

    2024-01-22 20:21:43
  • Pycharm编辑器技巧之自动导入模块详解

    2022-02-06 06:11:14
  • 教你如何使用Python下载B站视频的详细教程

    2023-04-12 00:39:48
  • python实现单张图像拼接与批量图片拼接

    2023-07-28 12:33:36
  • 深入浅出分析Python装饰器用法

    2022-10-25 16:49:02
  • MySQL中的联合索引学习教程

    2024-01-21 23:49:34
  • Microsoft .Net Remoting系列教程之一:.Net Remoting基础篇

    2024-05-09 09:03:35
  • python jupyter入门教程

    2022-08-19 20:42:04
  • 利用PyInstaller将python程序.py转为.exe的方法详解

    2021-07-09 16:41:51
  • 详解golang defer 闭包 匿名函数

    2024-02-11 09:19:20
  • Flask中嵌套启动子线程的方法示例详解

    2023-01-13 21:13:08
  • JavaScript ES6语法中let,const ,var 的区别

    2024-05-09 15:06:49
  • 使用Selenium破解新浪微博的四宫格验证码

    2021-06-16 11:22:28
  • spark编程python实例解读

    2023-06-02 06:12:52
  • asp MYSQL出现问号乱码的解决方法

    2011-04-15 11:13:00
  • 微信小程序时间轴实现方法示例

    2024-04-18 10:02:17
  • asp之家 网络编程 m.aspxhome.com