SQL中UNION 与 UNION ALL 的区别

区别

SQLServer2000中UNION与UNION ALL的区别

UNION 运算符:

将两个或更多查询的结果组合为单个结果集,该结果集包含联合查询中的所有查询的全部行。这与使用联接组合两个表中的列不同。

使用 UNION 组合两个查询的结果集的两个基本规则是:

所有查询中的列数和列的顺序必须相同。

数据类型必须兼容。

       这种多结果的查询组合为单一结果集在实际中应用的非常方便。但在应用中也有有着问题,如下实例可以进一步说明问题。

问题描述:

       为了进一步分析与统计企业中关键部件的生产进度情况,采用了一个表Key_Item_Cal,其结构如图一:

图一

通过联合查询,将查询分为三个方面:

1、提出数据的基础明细,其代码如下:

SELECT dbo.Key_item.Key_item_name AS Item_Name,

      dbo.H_MORVE.QTY_RECVD1 AS Quantity, dbo.Key_item.Style AS Style

FROM dbo.Key_item LEFT OUTER JOIN

      dbo.H_MORVE ON dbo.Key_item.Key_item = dbo.H_MORVE.ITEM

WHERE (dbo.Key_item.Key_item <> 1)

Order by Style asc

其结果为:

2、提出数据的一级汇总明细,其代码如下:

SELECT dbo.Key_item.Key_item_name AS Item_Name,

      SUM(dbo.H_MORVE.QTY_RECVD1) AS Quantity,MAX(dbo.Key_item.Style) AS Style

FROM dbo.Key_item LEFT OUTER JOIN

      dbo.H_MORVE ON dbo.Key_item.Key_item = dbo.H_MORVE.ITEM

WHERE (dbo.Key_item.Key_item <> 1)

GROUP BY dbo.Key_item.Style,dbo.Key_item.Key_item_name

order by Style

其结果如图如示:

3、提出数据的二级汇总明细,其代码如下:

SELECT MAX(dbo.Key_item.Key_item_name) as Item_Name,

SUM(dbo.H_MORVE.QTY_RECVD1) as Quantity,

      dbo.Key_item.Style as Style

FROM dbo.Key_item LEFT OUTER JOIN

      dbo.H_MORVE ON dbo.Key_item.Key_item = dbo.H_MORVE.ITEM

GROUP BY dbo.Key_item.Style

ORDER BY dbo.Key_item.Style asc

其结果如图所示:

       总体的设计就如以上所示,但通过UNION联接的时候出现了新的问题。通过以下例子,就可以看出UNION与UNION ALL的区别

方案一,其代码如下:

SELECT dbo.Key_item.Key_item_name AS Item_Name,

      dbo.H_MORVE.QTY_RECVD1 AS Quantity, dbo.Key_item.Style AS Style

FROM dbo.Key_item LEFT OUTER JOIN

      dbo.H_MORVE ON dbo.Key_item.Key_item = dbo.H_MORVE.ITEM

WHERE (dbo.Key_item.Key_item <> 1)

UNION (

SELECT dbo.Key_item.Key_item_name AS Item_Name,

      SUM(dbo.H_MORVE.QTY_RECVD1) AS Quantity,MAX(dbo.Key_item.Style) AS Style

FROM dbo.Key_item LEFT OUTER JOIN

      dbo.H_MORVE ON dbo.Key_item.Key_item = dbo.H_MORVE.ITEM

WHERE (dbo.Key_item.Key_item <> 1)

GROUP BY dbo.Key_item.Style,dbo.Key_item.Key_item_name

UNION

SELECT MAX(dbo.Key_item.Key_item_name) as Item_Name, SUM(dbo.H_MORVE.QTY_RECVD1) as Quantity,

      dbo.Key_item.Style as Style

FROM dbo.Key_item LEFT OUTER JOIN

      dbo.H_MORVE ON dbo.Key_item.Key_item = dbo.H_MORVE.ITEM

GROUP BY dbo.Key_item.Style)

ORDER BY dbo.Key_item.Style asc

GO

其结果如下:

问题:

       通过以上结果,可以发现GR180.14.2.1后机架、PY165G.14.2.1B后机架和PY165K.14.2.1后机架的明细与其二级汇总值明显不符。而二级汇总的值是正确,为什么明细与汇总值不符?

针对这个问题,我采用了第二种方案。

方案二,其代码如下:

SELECT dbo.Key_item.Key_item_name AS Item_Name,

      dbo.H_MORVE.QTY_RECVD1 AS Quantity, dbo.Key_item.Style AS Style

FROM dbo.Key_item LEFT OUTER JOIN

      dbo.H_MORVE ON dbo.Key_item.Key_item = dbo.H_MORVE.ITEM

WHERE (dbo.Key_item.Key_item <> 1)

UNION ALL(

SELECT dbo.Key_item.Key_item_name AS Item_Name,

      SUM(dbo.H_MORVE.QTY_RECVD1) AS Quantity,MAX(dbo.Key_item.Style) AS Style

FROM dbo.Key_item LEFT OUTER JOIN

      dbo.H_MORVE ON dbo.Key_item.Key_item = dbo.H_MORVE.ITEM

WHERE (dbo.Key_item.Key_item <> 1)

GROUP BY dbo.Key_item.Style,dbo.Key_item.Key_item_name

UNION

SELECT MAX(dbo.Key_item.Key_item_name) as Item_Name,

SUM(dbo.H_MORVE.QTY_RECVD1) as Quantity,

      dbo.Key_item.Style as Style

FROM dbo.Key_item LEFT OUTER JOIN

      dbo.H_MORVE ON dbo.Key_item.Key_item = dbo.H_MORVE.ITEM

GROUP BY dbo.Key_item.Style)

ORDER BY dbo.Key_item.Style asc

GO

其结果如图:

通过以上的例子,大家可以看出在UNION与UNION ALL在应用上区别。

本人是应界本科生,愿从事企业信息信息化建设,希望有用人需求的企业与我联系。

伊妹儿:Leew4u@126.com

本人静候

时间: 2024-11-08 22:31:12

SQL中UNION 与 UNION ALL 的区别的相关文章

SQL中varchar和nvarchar有什么区别?

原文:SQL中varchar和nvarchar有什么区别? varchar(n)长度为 n 个字节的可变长度且非 Unicode 的字符数据.n 必须是一个介于 1 和 8,000 之间的数值.存储大小为输入数据的字节的实际长度,而不是 n 个字节. nvarchar(n)包含 n 个字符的可变长度 Unicode 字符数据.n 的值必须介于 1 与 4,000 之间.字节的存储大小是所输入字符个数的两倍. 两字段分别有字段值:我和coffee那么varchar字段占2×2+6=10个字节的存储

数据库SQL中having和where的用法区别_MsSql

"Where" 是一个约束声明,使用Where来约束来之数据库的数据,Where是在结果返回之前起作用的,且Where中不能使用聚合函数. "Having"是一个过滤声明,是在查询返回结果集以后对查询结果进行的过滤操作,在Having中可以使用聚合函数.  聚合函数,SQL基本函数,聚合函数对一组值执行计算,并返回单个值.除了 COUNT 以外,聚合函数都会忽略空值. 聚合函数经常与 SELECT 语句的 GROUP BY 子句一起使用. Transact-SQL编

数据库SQL中having和where的用法区别

"Where" 是一个约束声明,使用Where来约束来之数据库的数据,Where是在结果返回之前起作用的,且Where中不能使用聚合函数. "Having"是一个过滤声明,是在查询返回结果集以后对查询结果进行的过滤操作,在Having中可以使用聚合函数. 聚合函数,SQL基本函数,聚合函数对一组值执行计算,并返回单个值.除了 COUNT 以外,聚合函数都会忽略空值. 聚合函数经常与 SELECT 语句的 GROUP BY 子句一起使用. Transact-SQL编程

SQL中JOIN和UNION区别、用法及示例介绍_MsSql

1.JOIN和UNION区别 join 是两张表做交连后里面条件相同的部分记录产生一个记录集, union是产生的两个记录集(字段要一样的)并在一起,成为一个新的记录集 . JOIN用于按照ON条件联接两个表,主要有四种: INNER JOIN:内部联接两个表中的记录,仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行.我理解的是只要记录不符合ON条件,就不会显示在结果集内. LEFT JOIN / LEFT OUTER JOIN:外部联接两个表中的记录,并包含左表中的全部记录.如果左表

SQL中JOIN和UNION区别、用法及示例介绍

1.JOIN和UNION区别 join 是两张表做交连后里面条件相同的部分记录产生一个记录集, union是产生的两个记录集(字段要一样的)并在一起,成为一个新的记录集 . JOIN用于按照ON条件联接两个表,主要有四种: INNER JOIN:内部联接两个表中的记录,仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行.我理解的是只要记录不符合ON条件,就不会显示在结果集内. LEFT JOIN / LEFT OUTER JOIN:外部联接两个表中的记录,并包含左表中的全部记录.如果左表

基于SQL中SET与SELECT赋值的区别详解_Mysql

最近的项目写的SQL比较多,经常会用到对变量赋值,而我使用SET和SELECT都会达到效果.那就有些迷惑,这两者有什么区别呢?什么时候哪该哪个呢?经过网上的查询,及个人练习,总结两者有以下几点主要区别:假定有设定变量: 复制代码 代码如下: DECLARE @VAR1 VARCHAR(1) DECLARE @VAR2 VARCHAR(2) 1.SELECT可以在一条语句里对多个变量同时赋值,而SET只能一次对一个变量赋值,如下: 复制代码 代码如下: SELECT @VAR1='Y',@VAR2

SQL中Execpt和not in 性能区别

主要讲 except 和 not in 的性能上的区别.  代码如下 复制代码 CREATE TABLE tb1(ID int)   CREATE TABLE tb2(ID int) BEGIN  TRAN DECLARE @i INT = 500 WHILE @i > 0 begin INSERT INTO dbo.tb1 VALUES  ( @i  -- v - int           ) SET @i = @i -1 end COMMIT 我测试的时候tb1 是1000,tb2 是50

sql中count(*)和count(字段名)区别

以前没有注意两者的区别,看博客园的文章,还真引起了我的注意. 数据测试:见图 sql 语句见分晓: SELECT COUNT(*) c1 ,COUNT(ADDRESS) c2 FROM test 显而易见,count(*)统计的是结果集的总条数,count(字段名)统计的是该字段值不为null的总条数 以上是小编为您精心准备的的内容,在的博客.问答.公众号.人物.课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索数据 , 测试 null sql查询表的字段名.sql 修改字段名.sql

SQL中truncate、delete与drop区别

一.相同点 1 truncate.不带where子句的delete.drop都会删除表内的数据 2 drop.truncate都是DDL语句(数据定义语言),执行后会自动提交 二.不同点 1 truncate 和 delete 只删除数据不删除表的结构(定义) drop语句将删除表的结构被依赖的约束(constrain).触发器(trigger).索引(index):依赖于该表的存储过程/函数将保留,但是变为 invalid 状态. 2 delete语句是数据库操作语言(dml),这个操作会放到