Oracle Union Union All 使用方法

1.Union 指令的目的是将两个SQL语句的结果合并起来,可以查看你需要查询结果

例如:

SELECT Date FROM Store_Information

UNION

SELECT Date FROM Internet_Sales;

注意:

union用法中,两个SELECT 语句的字段类型匹配,并且字段的类型要相同

如上面的例子,在实际的软件开发过程,会遇到更复杂的情况,具体请看下面的额子

select '1' as type,FL_ID ,FL_CODE,FL_CNAME,_FLDA,FL_PARENTID from FLDA

WHERE ZT_ID = 2006030002

union

SELECT '2' as Tpye,XM_ID,_XM_CODE,XM_CNAME,FL_ID FROM XMDA

WHERE exists (SELECT * FROM (SELECT FL_FL_ID FROM FLDA WHERE ZT_ID=200603002 ) a where XMDA.fl_id=fl_id)

order by type,FL_PARENTID , FL_ID;

这句话的意思是将两个SQL语句UNION 查询出来,查询的条件就是看XMDA表中额FL_ID是否和主表FLDA里的FL_ID值匹配(也就是存在)

UNION在进行表连接后会筛选掉重复的额记录,所以表连接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果。

2.在查询中会遇到UNION ALL,他的用法和UNION一样,只不过UNION包含distinct的功能,它会把两张表重复了的记录去掉,

而union all不会, 所以从效率上讲,union all 会高一点,但实际中用得到的并不是很多。

表头会用到第一个连接块的字段

而UNION all只是简单的将两个结果合并后就返回,这样,如果返回到额两个结果集中有重复的额数据,那么返回到结果集就半含重复的数据了。

从效率上来说,UNION ALL 要比 UNION快的多,所以,如果可以确认合并的两个结果集不包含重复的数据的话,那么就使用UNION ALL如下:

尽量使用UNION ALL,因为UNION需要进行排序,去除重复记录,效率低。





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值