集合操作UNION、UNION ALL、INTERSECT、MINUS区别
2015-04-24 10:49
666 查看
有两个表job_history表有10条数据;employees表有107条数据,这两个表有2条数据是重复的
SQL> ed
已写入 file afiedt.buf
1 SELECT employee_id id, job_id
2 FROM employees
3 minus
4 SELECT employee_id id, job_id
5* FROM job_history
SQL> /
表示返回在employees中存在,而不在job_history中的记录,返回105条数据,去掉了2条重复的数据
SQL> ed
已写入 file afiedt.buf
1 SELECT employee_id id, job_id
2 FROM job_history
3 minus
4 SELECT employee_id id, job_id
5* FROM employees
SQL> /
表示返回在job_history中存在,而不在employees中的记录,返回8条数据,去掉了2条重复的数据
集合操作中的ORDER BY子句
只能在整个集合的最后出现.可以按照第一个SELECT语句中的列名, 别名或者位置号排序.
SQL> ed
已写入 file afiedt.buf
1 SELECT employee_id id, job_id
2 FROM employees
3 UNION all
4 SELECT employee_id, job_id
5 FROM job_history
6* order by employee_id
SQL> /
下面的语句是正确的
SQL> ed
已写入 file afiedt.buf
1 SELECT employee_id, job_id
2 FROM employees
3 UNION all
4 SELECT employee_id id, job_id
5 FROM job_history
6* order by employee_id
SQL> /
小结
在SELECT 列表中的表达是必须有同样的数目和类型.
在结果中显示第一个Select语句中的列名.
除了 UNION ALL操作外,其他的集合操作都自动去掉重复值.
所以其他操作会隐式的进行排序操作(sql语句中并没有order by),使用CPU资源.
除了UNION ALL操作外,其他集合操作的输出结果默认按照升序的次序排列 .
所以其他操作会隐式的进行排序操作(sql语句中并没有order by),使用CPU资源.
SQL> ed
已写入 file afiedt.buf
1 SELECT employee_id id, job_id
2 FROM employees
3 minus
4 SELECT employee_id id, job_id
5* FROM job_history
SQL> /
表示返回在employees中存在,而不在job_history中的记录,返回105条数据,去掉了2条重复的数据
SQL> ed
已写入 file afiedt.buf
1 SELECT employee_id id, job_id
2 FROM job_history
3 minus
4 SELECT employee_id id, job_id
5* FROM employees
SQL> /
表示返回在job_history中存在,而不在employees中的记录,返回8条数据,去掉了2条重复的数据
集合操作中的ORDER BY子句
只能在整个集合的最后出现.可以按照第一个SELECT语句中的列名, 别名或者位置号排序.
SQL> ed
已写入 file afiedt.buf
1 SELECT employee_id id, job_id
2 FROM employees
3 UNION all
4 SELECT employee_id, job_id
5 FROM job_history
6* order by employee_id
SQL> /
下面的语句是正确的
SQL> ed
已写入 file afiedt.buf
1 SELECT employee_id, job_id
2 FROM employees
3 UNION all
4 SELECT employee_id id, job_id
5 FROM job_history
6* order by employee_id
SQL> /
小结
在SELECT 列表中的表达是必须有同样的数目和类型.
在结果中显示第一个Select语句中的列名.
除了 UNION ALL操作外,其他的集合操作都自动去掉重复值.
所以其他操作会隐式的进行排序操作(sql语句中并没有order by),使用CPU资源.
除了UNION ALL操作外,其他集合操作的输出结果默认按照升序的次序排列 .
所以其他操作会隐式的进行排序操作(sql语句中并没有order by),使用CPU资源.
相关文章推荐
- 集合操作UNION、UNION ALL、INTERSECT、MINUS区别
- ORACLE集合操作符号UNION、UNION ALL、INTERSECT、MINUS来进行查询结果的合并操作
- Oracle集合操作函数:Union、Union All、Intersect、Minus
- Oracle 四种结果集集合操作命令 Union、Union All、Intersect、Minus
- 集合操作,union,union all,intersect, minus
- Oracle 四种结果集集合操作命令 Union、Union All、Intersect、Minus
- Oracle 四种结果集集合操作命令 Union、Union All、Intersect、Minus
- Oracle集合操作函数:Union、Union All、Intersect、Minus
- oracle中Union,Union All,Intersect和Minus操作异同
- 常用SQL查询语句 Oracle中Union,Union All,Intersect,Minus的有什么区别
- 【转】Oracle集合操作函数:union、intersect、minus
- Oracle 集合操作函数:union、intersect、minus
- Oracle中的Union、Union All、Intersect、Minus 使用用法区别
- ORACLE集合操作函数:UNION、INTERSECT、MINUS
- Intersect,Minus,union all 和union的区别
- Intersect,Minus,union all 和union的区别
- Oracle集合操作函数:union、intersect、minus
- 【oracle】union、union all、intersect、minus 的用法及区别
- oracle之集合操作函数---minus、union、intersect
- SQL中浅谈union、union all、Intersect、Minus的区别