用 ROLLUP 汇总数据
在生成包含小计和合计的报表时,ROLLUP 运算符很有用。ROLLUP 运算符生成的结果集类似于 CUBE 运算符所生成的结果集。有关更多信息,请参见用 CUBE 汇总数据。 CUBE 和 ROLLUP 之间的区别在于: CUBE 生成的结果集显示了所选列中值的所有组合的聚合。
ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合。
例如,简单表 Inventory 中包含:Item Color Quantity
-------------------- -------------------- --------------------------
Table Blue 124
Table Red 223
Chair Blue 101
Chair Red 210 下列查询将生成小计报表:SELECT CASE WHEN (GROUPING(Item) = 1) THEN 'ALL'
ELSE ISNULL(Item, 'UNKNOWN')
END AS Item,
CASE WHEN (GROUPING(Color) = 1) THEN 'ALL'
ELSE ISNULL(Color, 'UNKNOWN')
END AS Color,
SUM(Quantity) AS QtySum
FROM Inventory
GROUP BY Item, Color WITH ROLLUPItem Color QtySum
-------------------- -------------------- --------------------------
Chair Blue 101.00
Chair Red 210.00
Chair ALL 311.00
Table Blue 124.00
Table Red 223.00
Table ALL 347.00
ALL ALL 658.00 (7 row(s) affected)如果查询中的 ROLLUP 关键字更改为 CUBE,那么 CUBE 结果集与上述结果相同,只是在结果集的末尾还会返回下列两行:ALL Blue 225.00
ALL Red 433.00 CUBE 操作为 Item 和 Color 中值的可能组合生成行。例如,CUBE 不仅报告与 Item 值 Chair 相组合的 Color 值的所有可能组合(Red、Blue 和 Red + Blue),而且报告与 Color 值 Red 相组合的 Item 值的所有可能组合(Chair、Table 和 Chair + Table)。对于 GROUP BY 子句中右边的列中的每个值,ROLLUP 操作并不报告左边一列(或左边各列)中值的所有可能组合。例如,ROLLUP 并不对每个 Color 值报告 Item 值的所有可能组合。ROLLUP 操作的结果集具有类似于 COMPUTE BY 所返回结果集的功能;然而,ROLLUP 具有下列优点: ROLLUP 返回单个结果集;COMPUTE BY 返回多个结果集,而多个结果集会增加应用程序代码的复杂性。
ROLLUP 可以在服务器游标中使用;COMPUTE BY 不可以。
有时,查询优化器为 ROLLUP 生成的执行计划比为 COMPUTE BY 生成的更为高效。
在生成包含小计和合计的报表时,ROLLUP 运算符很有用。ROLLUP 运算符生成的结果集类似于 CUBE 运算符所生成的结果集。有关更多信息,请参见用 CUBE 汇总数据。 CUBE 和 ROLLUP 之间的区别在于: CUBE 生成的结果集显示了所选列中值的所有组合的聚合。
ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合。
例如,简单表 Inventory 中包含:Item Color Quantity
-------------------- -------------------- --------------------------
Table Blue 124
Table Red 223
Chair Blue 101
Chair Red 210 下列查询将生成小计报表:SELECT CASE WHEN (GROUPING(Item) = 1) THEN 'ALL'
ELSE ISNULL(Item, 'UNKNOWN')
END AS Item,
CASE WHEN (GROUPING(Color) = 1) THEN 'ALL'
ELSE ISNULL(Color, 'UNKNOWN')
END AS Color,
SUM(Quantity) AS QtySum
FROM Inventory
GROUP BY Item, Color WITH ROLLUPItem Color QtySum
-------------------- -------------------- --------------------------
Chair Blue 101.00
Chair Red 210.00
Chair ALL 311.00
Table Blue 124.00
Table Red 223.00
Table ALL 347.00
ALL ALL 658.00 (7 row(s) affected)如果查询中的 ROLLUP 关键字更改为 CUBE,那么 CUBE 结果集与上述结果相同,只是在结果集的末尾还会返回下列两行:ALL Blue 225.00
ALL Red 433.00 CUBE 操作为 Item 和 Color 中值的可能组合生成行。例如,CUBE 不仅报告与 Item 值 Chair 相组合的 Color 值的所有可能组合(Red、Blue 和 Red + Blue),而且报告与 Color 值 Red 相组合的 Item 值的所有可能组合(Chair、Table 和 Chair + Table)。对于 GROUP BY 子句中右边的列中的每个值,ROLLUP 操作并不报告左边一列(或左边各列)中值的所有可能组合。例如,ROLLUP 并不对每个 Color 值报告 Item 值的所有可能组合。ROLLUP 操作的结果集具有类似于 COMPUTE BY 所返回结果集的功能;然而,ROLLUP 具有下列优点: ROLLUP 返回单个结果集;COMPUTE BY 返回多个结果集,而多个结果集会增加应用程序代码的复杂性。
ROLLUP 可以在服务器游标中使用;COMPUTE BY 不可以。
有时,查询优化器为 ROLLUP 生成的执行计划比为 COMPUTE BY 生成的更为高效。
else isnull(p.ProdID,'unknow')
end as goodsid,
case when (grouping(c.cartitemid)=1) then 0
else isnull(c.cartitemid,'unknow')
end as cartitemid, sum(c.Quantity) as Quantity,
sum(c.Quantity * p.Price) as PriceTotal,
sum(c.Quantity * p.NewPrice) as NewPriceTotal
from Shop_Cart c inner join Shop_Product p on c.ProdID=p.ProdID
where c.cartid='00001'
group by p.goodsid,c.cartitemid with rollup--cartitemid 为0代表小计
p.Price, p.NewPrice,
PriceTotal = (c.Quantity * p.Price),
NewPriceTotal = (c.Quantity * p.NewPrice)
FROM Shop_Cart c
INNER JOIN Shop_Product p on c.ProdID = p.ProdID
WHERE c.CartID = @CartID
union all
SELECT c.ProdID, c.Quantity, c.CartItemID,
sum(p.Price), sum(p.NewPrice),
PriceTotal = sum(c.Quantity * p.Price),
NewPriceTotal = sum(c.Quantity * p.NewPrice)
FROM Shop_Cart c
INNER JOIN Shop_Product p on c.ProdID = p.ProdID
WHERE c.CartID = @CartID
group by c.ProdID, c.Quantity, c.CartItemID
感觉用邹老的应该可以,
若需要排序的,
就这样:
select ProdID,
Quantity,
CartItemID,
Price,
NewPrice,
PriceTotal ,
NewPriceTotal
from (邹老的语句) a
order by ProdID
zjcxc(邹建) 的方法我试了一下,是把汇总放在最后一行了。但是我在asp.net中如何取出来呢?
DataView CartDV = shopCart.GetCartItems().Tables[0].DefaultView;
RpShopCart.DataSource = CartDV;
RpShopCart.DataBind();本来应该是:商品 市场价 优惠价 数量 市场价小计 优惠价小计笔记本 4.00 3.00 3 12.00 9.00
书包 12.00 10.00 1 12.00 10.99 总计 4 24.00 19.99结果却是:
商品 市场价 优惠价 数量 市场价小计 优惠价小计笔记本 4.00 3.00 3 12.00 9.00
总计 4.00 3.00 3 24.00 19.00
书包 12.00 10.00 1 12.00 10.99
总计 4.00 3.00 3 24.00 19.00
SELECT c.ProdID, p.ProdName, c.Quantity, c.CartItemID, p.RetailPrice, p.ActualPrice,
RetailPriceTotal = (c.Quantity * p.RetailPrice),ActualPriceTotal = (c.Quantity * p.ActualPrice)
FROM Shop_Cart c INNER JOIN Shop_Product p on
c.ProdID = p.ProdID
WHERE c.CartID = @CartID另外一个专门查总计。那个查总计的我这样写:
SELECT Quantity = sum(c.Quantity),RetailPrice=p.RetailPrice, ActualPrice=p.ActualPrice, RetailPriceTotal = sum(c.Quantity * p.RetailPrice),
ActualPriceTotal = sum(c.Quantity * p.ActualPrice)
FROM Shop_Cart c
INNER JOIN Shop_Product p on c.ProdID = p.ProdID
WHERE c.CartID = @CartID
group by c.ProdID, c.Quantity, c.CartItemID结果不行。老是说少了 ProdID,ProdName.请问只查总计的语句怎么写?
书包 12.00 10.00 1 12.00 10.00 总计 4 24.00 19.00
我要求的查询结果就是: 总数量TotalQuantity(应该是4),总市场价TotalPrice(应该是24),总优惠价(应该是19)