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
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
BP神经网络原理及Python实现代码
![](https://img.aspxhome.com/file/2023/8/72148_0s.jpg)
Python3监控疫情的完整代码
![](https://img.aspxhome.com/file/2023/2/83782_0s.jpg)
SQL中的开窗函数详解可代替聚合函数使用
![](https://img.aspxhome.com/file/2023/7/86877_0s.png)
浅谈MySQL之select优化方案
SQL汇总统计与GROUP BY过滤查询实现
![](https://img.aspxhome.com/file/2023/9/105499_0s.png)
Pycharm编辑器技巧之自动导入模块详解
![](https://img.aspxhome.com/file/2023/4/127844_0s.png)
教你如何使用Python下载B站视频的详细教程
![](https://img.aspxhome.com/file/2023/8/102768_0s.jpg)
python实现单张图像拼接与批量图片拼接
![](https://img.aspxhome.com/file/2023/0/59300_0s.jpg)
深入浅出分析Python装饰器用法
MySQL中的联合索引学习教程
Microsoft .Net Remoting系列教程之一:.Net Remoting基础篇
![](https://img.aspxhome.com/file/2023/2/129812_0s.jpg)
python jupyter入门教程
![](https://img.aspxhome.com/file/2023/3/120583_0s.png)
利用PyInstaller将python程序.py转为.exe的方法详解
详解golang defer 闭包 匿名函数
Flask中嵌套启动子线程的方法示例详解
![](https://img.aspxhome.com/file/2023/2/133852_0s.png)
JavaScript ES6语法中let,const ,var 的区别
使用Selenium破解新浪微博的四宫格验证码
![](https://img.aspxhome.com/file/2023/9/76869_0s.png)
spark编程python实例解读
![](https://img.aspxhome.com/file/2023/4/115704_0s.png)
asp MYSQL出现问号乱码的解决方法
微信小程序时间轴实现方法示例
![](https://img.aspxhome.com/file/2023/8/136138_0s.png)