UNION 和UNION ALL 的区别
2016-03-31 15:12
253 查看
UNION:的结果集没有重复行,且安union默认的排序规则进行排序了。
UNION ALL:的结果集,如果各表有重复行就有重复行,不删重复行,不排序。
-------------------------
在数据库中,UNION和UNION ALL关键字都是将两个结果集合并为一个,但这两者从使用和效率上来说都有所不同。
UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果。
实际大部分应用中是不会产生重复的记录,最常见的是过程表与历史表UNION。如:
select * from gc_dfys
union
select * from ls_jg_dfys
这个SQL在运行时先取出两个表的结果,再用排序空间进行排序删除重复的记录,最后返回结果集,如果表数据量大的话可能会导致用磁盘进行排序。
而UNION ALL只是简单的将两个结果合并后就返回。这样,如果返回的两个结果集中有重复的数据,那么返回的结果集就会包含重复的数据了。
从效率上说,UNION ALL 要比UNION快很多,所以,如果可以确认合并的两个结果集中不包含重复的数据的话,那么就使用UNION ALL,如下:
select * from gc_dfys
union all
select * from ls_jg_dfys
UNION ALL:的结果集,如果各表有重复行就有重复行,不删重复行,不排序。
-------------------------
在数据库中,UNION和UNION ALL关键字都是将两个结果集合并为一个,但这两者从使用和效率上来说都有所不同。
UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果。
实际大部分应用中是不会产生重复的记录,最常见的是过程表与历史表UNION。如:
select * from gc_dfys
union
select * from ls_jg_dfys
这个SQL在运行时先取出两个表的结果,再用排序空间进行排序删除重复的记录,最后返回结果集,如果表数据量大的话可能会导致用磁盘进行排序。
而UNION ALL只是简单的将两个结果合并后就返回。这样,如果返回的两个结果集中有重复的数据,那么返回的结果集就会包含重复的数据了。
从效率上说,UNION ALL 要比UNION快很多,所以,如果可以确认合并的两个结果集中不包含重复的数据的话,那么就使用UNION ALL,如下:
select * from gc_dfys
union all
select * from ls_jg_dfys
相关文章推荐
- leetcode 231. Power of Two
- MyBatis crud操作
- Python之异步IO&RabbitMQ&Redis
- 网易实习生真题(二叉树)
- 管道和FIFO
- js实现定时添加代码
- 数据库索引
- Android中解决scrollview中嵌套listview的listview只显示一行的问题
- bzoj3011 可并堆
- ${pageContext.request.contextPath} JSP路径问题
- leetcode04-Median of Two Sorted Arrays-python
- unity3d的playmaker插件使用教程,四、物品破坏,道具拾取
- Tomcat内存溢出的几点方案
- altium designer 软件常用技巧总结(实时更新)
- NATS服务器配置详解
- 文章标题
- 升级数据库的最佳写法
- keepalived与lvs 调度算法
- linux系统下mysql跳过密码验证登录
- 我的2016年linux学习决心书