用 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 生成的更为高效。 

解决方案 »

  1.   

    select case when (grouping(p.ProdID)=1) then '总计'
                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代表小计
      

  2.   

    SELECT c.ProdID, c.Quantity, c.CartItemID, 
    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
      

  3.   

    学习一下,
    感觉用邹老的应该可以,
    若需要排序的,
    就这样:
    select ProdID, 
           Quantity, 
           CartItemID, 
           Price, 
           NewPrice, 
           PriceTotal ,
           NewPriceTotal 
      from (邹老的语句) a
      order by ProdID
      

  4.   

    CSDN 登录出故障了!
    zjcxc(邹建) 的方法我试了一下,是把汇总放在最后一行了。但是我在asp.net中如何取出来呢?
      

  5.   

    我写的是一条的SQL语句,和执行没有union all的语句取结果的方法是一样的啊
      

  6.   

    实际执行时除了应该有的行之外,还多了一个汇总行,我在购物车数据绑定时会重复。
    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
      

  7.   

    还有,money 数据怎么会显示为 4.0000 后面多处的两个0如何去掉。
      

  8.   

    请问邹大哥,如果用两个查询语句如何?一个语句查小计:
    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.请问只查总计的语句怎么写?
      

  9.   

    几个语句用union all 合并起来就行了要求列数相同,如果后面合计处理的,缺少对应的列,则应该用''为补充缺少的列至于汇总最终结果会多一列,就不知道了怎么回事了,你先在查询分析器中把语句调正确吧.
      

  10.   

    商品   市场价  优惠价  数量  市场价小计  优惠价小计笔记本   4.00   3.00    3       12.00       9.00
    书包     12.00  10.00   1       12.00       10.00    总计                4        24.00       19.00
    我要求的查询结果就是: 总数量TotalQuantity(应该是4),总市场价TotalPrice(应该是24),总优惠价(应该是19)
      

  11.   

    咳,很简单,是不是去掉GROUP语句就行了?
      

  12.   

    是的,去掉GROUP语句就行了。多谢邹大哥!!!!!!!! 但是 money数据在显示时小数点后总是有4个0,如何只要2个0  ?
      

  13.   

    忧郁,money 数据怎么会显示为 4.0000 后面多处的两个0如何去掉?
      

  14.   

    忧郁,money 数据怎么会显示为 4.0000 后面多处的两个0如何去掉?cast(money as numeric(14,2))