数据库教程:总结下sqlserver group by 的用法

今天用实例总结一下group by的用法。 归纳一下:group by:all ,cube,rollup,compute,compute by 创建数据脚本 crea

今天用实例总结一下group by的用法。

归纳一下:group by:all ,cube,rollup,compute,compute by

创建数据脚本

create table salesinfo
(ctiy nvarchar(50),
orderdate datetime,
orderid int
)

insert into salesinfo
select n’北京’,’2014-06-09′,1001
union all
select n’北京’,’2014-08-09′,1002
union all
select n’北京’,’2013-10-09′,1009
union all
select n’大连’,’2013-08-09′,4001
union all
select n’大连’,’2013-10-09′,4002
union all
select n’大连’,’2013-05-12′,4003
union all
select n’大连’,’2014-11-11′,4004
union all
select n’大连’,’2014-12-11′,4005

首先执行以下脚本:

select ctiy,count(orderid) as ordercount
from
salesinfo
group by ctiy
with cube

总结下sqlserver group by 的用法

可以看到多出了一行 是对所有的订单数的汇总

下一个脚本:

select ctiy,year(orderdate) as orderyear,count(orderid) as ordercount
from
salesinfo
group by ctiy,year(orderdate)
with cube

总结下sqlserver group by 的用法

可以看出来对分组中的维度都进行了汇总,并且还有一个订单的总和

下一个脚本(注意出现了rollup):

select ctiy,year(orderdate) as orderyear,count(orderid) as ordercount
from
salesinfo
group by ctiy,year(orderdate)
with rollup

总结下sqlserver group by 的用法

使用rollup会对group by列出的第一个分组字段进行汇总运算

下一个脚本:

select ctiy,count(orderid) as ordercount
from
salesinfo
where
ctiy = n’大连’
group by all ctiy

我们会看到 使用group by all 后,不符合条件的城市也会出现,只是订单数是零

需要注意的是 all 不能和 cube 和 rollup一起使用,和having一起使用的话,all的功能会失效.

下一个脚本:

select ctiy,orderdate,orderid
from
salesinfo
compute count(orderid)

总结下sqlserver group by 的用法

显示了两个结果集,一个是订单结果集,一个是订单总数结果集

最后一个脚本:

select ctiy,orderdate,orderid
from
salesinfo
order by ctiy
compute count(orderid) by ctiy

总结下sqlserver group by 的用法

按照不同的城市,分别显示该城市的订单信息,一个显示该城市的所有订单数量

就先说这些了.

需要了解更多数据库技术:总结下sqlserver group by 的用法,都可以关注数据库技术分享栏目—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/615775.html

(0)
上一篇 2021年5月20日
下一篇 2021年5月20日

精彩推荐