Union与Union All

如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字。union的作用是将多个结果合并在一起显示出来。
union和union all的区别是,union会自动压缩多个结果集合中的重复结果,而union all则将所有的结果全部显示出来,不管是不是重复。

Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
Union All:对两个结果集进行并集操作,包括重复行,不进行排序;
Intersect:对两个结果集进行交集操作,不包括重复行,同时进行默认规则的排序;
Minus:对两个结果集进行差操作,不包括重复行,同时进行默认规则的排序。

selectemployee_id,job_id from employees union selectemployee_id,job_id from job_history

使用union和union all必须保证各个select 集合的结果有相同个数的列,并且每个列的类型是一样的。但列名则不一定需要相同,oracle会将第一个结果的列名作为结果集的列名。
select empno,ename from emp union select deptno,dname from dept

可以在最后使用一条order by来对整个结果进行排序。

推荐阅读更多精彩内容

  • 前言 学习到此内容是因为工作上的需求而接触到的,起初是对单表进行操作,需要对某一字段下的值进行分组统计次数并排序,...
    杀死一只程序猿阅读 441评论 0 0
  • 1. 问题的提出## 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的的编写等体会不出...
    七寸知架构阅读 4,475评论 1 111
  • 作词:归海临秋 天凉后树林中 开始变得静寂 落下黄叶 不再眷恋青绿 簪一头菊 月落时披上夹衣 幽径深 缓缓踏霜露成...
    归海临秋阅读 110评论 0 1
  • 一年了,我们还是分手了,彼此成全,彼此存情安放,不怪结局太遗憾,只怪命运让我们相遇爱过一场。 文/季童 一、丽江遇...
    季童阅读 970评论 56 40
  • 你总是间歇性踌躇满志 持续性混吃等死
    走好不送阅读 49评论 0 0