SQL查询的时候同时显示明细和总计

当我们要查询明细和总计的时候,通常使用的方法是

方法一:

select item ,sum(xx) from xxx group by item

union

select null ,sum(xx) from xxx 

方法二:

但是SQL server其实有两个简单的函数可以实现上面的功能

Rollup ():分组同时求明细

Grouping():判断是否是分组的列,1表示聚合列,0表示不是

代码:

SELECT grouping(StoreID)grouptag,StoreID,sum(sales)
  FROM xxx
  where storeid in (1xx ,26xx,
26xx
)
  and SalesDate between '20190801' and '20190808'
  group by rollup(StoreID)

结果:

方法三:

使用cube也可以达到同样的效果

代码

SELECT grouping(StoreID)grouptag,StoreID,sum(sales)
  FROM xxxx
  where storeid in (1xx ,26xx,
26xx
)
  and SalesDate between '20190801' and '20190808'
  group by StoreID with cube

结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值