[转]集合操作UNION、UNION ALL、INTERSECT、MINUS区别

阅读更多

有两个表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资源.

 

(转自:http://www.cnblogs.com/simplefrog/archive/2012/07/15/2592380.html

你可能感兴趣的:(集合,数据库)