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 子查询的资料请关注其它相关文章!
更多相关Mysql内容来自木庄网络博客
标签:Mysql
相关阅读 >>
更多相关阅读请进入《mysql》频道 >>
数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。