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 子查询的资料请关注脚本之家其它相关文章!
相关文章
IDEA使用mybatis-generator及配上mysql8.0.3版本遇到的bug
这篇文章主要介绍了IDEA使用mybatis-generator以及配上mysql8.0.3版本遇到的问题,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-11-11sqoop export导出 map100% reduce0% 卡住的多种原因及解决
这篇文章主要介绍了sqoop export导出 map100% reduce0% 卡住的多种原因及解决,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2021-01-01Windows安装MySQL后怎么开启root的网络访问权限
Windows安装MySQL后默认只能本机访问,怎么开启网络访问,本文给大家介绍介绍了Windows安装MySQL后怎么开启root的网络访问权限,需要的朋友可以参考下2023-08-08完美解决mysql in条件语句只读取一条信息问题的2种方案
使用mysql多表查询时一个表中的某个字段作为另一表的in查询条件,只能读取一条信息,而直接用数字的话可以正常读取2018-04-04MySQL中出现lock wait timeout exceeded问题及解决
这篇文章主要介绍了MySQL中出现lock wait timeout exceeded问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-08-08mysql 一个较特殊的问题:You can''t specify target table ''wms_cabinet
mysql 一个较特殊的问题:You can't specify target table 'wms_cabinet_form' for update in F2010-11-11windows下MySQL 5.7.3.0安装配置图解教程(安装版)
这篇文章主要介绍了windows下MySQL 5.7.3.0安装配置图解教程(安装版),需要的朋友可以参考下2016-04-04
最新评论