UNION 和UNION ALL 的区别
来源:互联网 发布:孝庸资产知乎 编辑:程序博客网 时间:2024/04/30 17:13
在数据库中,UNION和UNION ALL关键字都是将两个结果集合并为一个,但这两者从使用和效率上来说都有所不
同。
UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重
复的记录再返回结果集。
实际上大部分应用中是不会产生重复的记录,最常见的是过程表与历史表UNION。如:
select * from table1
union
select * from table2
这个SQL在运行时先取出两个表的结果,再利用排序空间进行排序删除重复的记录,最后返回结果集。如
果表数据量大的话可能会导致用磁盘进行排序。
而UNION ALL只是简单的将两个结果集合并后就返回。这样,如果返回的两个结果集中有重复的数据,那
么返回的结果集就会包含重复的数据了。
从效率上说,UNION ALL 要比UNION快很多,所以,如果可以确认合并的两个结果集中不包含重复的数据
的话,那么就使用UNION ALL,如下:
select * from table1
union all
select * from table2
- UNION 和UNION ALL 的区别
- UNION和UNION ALL的区别
- UNION 和UNION ALL 的区别
- UNION 和UNION ALL 的区别
- union和union all的区别
- union和union all的区别
- UNION 和UNION ALL 的区别
- UNION和UNION ALL的区别
- UNION 和UNION ALL 的区别
- UNION 和UNION ALL 的区别
- UNION和UNION ALL 的区别
- [SQL] Union和Union All的区别
- UNION 和UNION ALL 的区别
- UNION 和UNION ALL 的区别
- union 和 union all 的区别
- UNION 和UNION ALL的区别
- SQL UNION 和 UNION ALL的区别
- UNION 和UNION ALL 的区别
- 中文字符
- Yahoo javascript 开源界面库YUI 和EXT
- intel32位保护模式简述
- 微软收购DATAllegro 挺进企业商业智能市场
- 保护模式
- UNION 和UNION ALL 的区别
- POJ1011 Sticks解题报告(经典搜索)
- 编写、编译、安装、移除一个内核模块的基本过程,不能再简单了的
- 存储过程中的 SET NOCOUNT ON 什么意思?
- 我来了
- C# 信号量的使用
- bmp 到IplImage的转换
- sql server日期时间函数
- C# HttpWebRequest人异步访问