UNION和UNION-ALL之间有什么区别
UNION删除重复记录(其中结果中的所有列都相同),UNION all不删除
如果使用UNION而不是UNION ALL,则会对性能造成影响,因为数据库服务器必须执行额外的工作来删除重复的行,但通常您不需要重复的行(尤其是在开发报表时)
要识别重复项,记录必须是可比较的类型以及兼容的类型。这将取决于SQL系统。例如,系统可能会截断所有长文本字段以生成用于比较的短文本字段(MS Jet),或者可能会拒绝比较二进制字段(ORACLE)
工会示例:
选择“foo”作为条形接头选择“foo”作为条形接头
结果:
+-----+
|酒吧|
+-----+
|福|
+-----+
一行一组(0.00秒)
联合所有示例:
选择“foo”作为条形接头所有选择“foo”作为条形接头
结果:
+-----+
|酒吧|
+-----+
|福|
|福|
+-----+
一组2行(0.00秒)