Sql学习第四天——SQL 关于with cube,with rollup和grouping解释
通过结果图的比较发现猜想是正确的。
select [name],numb from dbo.PeopleInfo group by [name],numb with rollup查询出插入的全部数据:
---------------------------------------------------grouping-------------------------------------------------

insert into peopleinfo([name],numb,phone,fenshu) values ('李名','32132312','13342563',60)
insert into peopleinfo([name],numb,phone,fenshu) values ('王华','3223','1365255',80)
复制代码 代码如下:
操作一:先试试:1, 查询所有数据;2,用group by 查询所有数据;3,用with cube。这三种情况的比较
[numb] [nchar](10) COLLATE Chinese_PRC_CI_AS NOT NULL,复制代码 代码如下:
[FenShu] [int] NULL
SQL语句如下:
SQL语句看看与with rollup的结合(与with cube的结合是一样的):
) ON [PRIMARY]
[phone] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL,
通过查看sql 2005的帮助文档找到了CUBE 和 ROLLUP 之间的具体区别:
复制代码 代码如下:
select [name],numb,sum(fenshu) from dbo.PeopleInfo group by [name],numb with rollup --用with rollup。复制代码 代码如下:
[id] [int] IDENTITY(1,1) NOT NULL,先建表(dbo.PeopleInfo):
仅在与包含 CUBE 或 ROLLUP 运算符的 GROUP BY 子句相关联的选择列表中才允许分组。
复制代码 代码如下:
SQL语句如下:

select * from dbo.PeopleInfo --1, 查询所有数据;
当行由 CUBE 或 ROLLUP 运算符添加时,该函数将导致附加列的输出值为 1;当行不由 CUBE 或 ROLLUP 运算符添加时,该函数将导致附加列的输出值为 0。
select [name],numb,phone from dbo.PeopleInfo group by [name],numb,phone with rollup为什么with cube 比 with rollup多出来一部分呢?原来它没有显示,以【numb】分组而不考虑【name】的数据情况。再回顾一下帮助文档的解释:ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合,那这个【某一层次】又是以什么为标准的呢?我的猜想是:距离group up最近的字段必须考虑在分组内。
SQL语句如下:


再看看对grouping的解释:
结果如图:
操作二:1,用with cube;2,用with rollup 这两种情况的比较
操作:用两个group up 交换字段位置的sql语句和一个在group up 后面增加一个字段的sql语句进行比较:
select * from dbo.PeopleInfo
复制代码 代码如下:
向表插入数据:现在来看看grouping的实例:
insert into peopleinfo([name],numb,phone,fenshu) values ('李名','3213112352','13152',56)复制代码 代码如下:
select [name],numb,sum(fenshu) from dbo.PeopleInfo group by [name],numb with cube --用with cube。结果分析:
select [name],numb from dbo.PeopleInfo group by numb,[name] with rollup[name] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL,
CUBE 生成的结果集显示了所选列中值的所有组合的聚合。ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合。
结果如图:select [name],numb,sum(fenshu) from dbo.PeopleInfo group by [name],numb with cube --3,用with cube。这三种情况的比较
结果分析:
结果如图:insert into peopleinfo([name],numb,phone,fenshu) values ('李欢','322123','1',90)
select [name],numb,sum(fenshu) from dbo.PeopleInfo group by [name],numb --2,用group by 查询所有数据;
证明猜想实例:
insert into peopleinfo([name],numb,phone,fenshu) values ('李欢','3223','1365255',80)
当看到以上的解释肯定非常的模糊,不知所云和不知道该怎样用,下面通过实例操作来体验一下:
关于with cube ,with rollup 和 grouping
用第三种(用with cube)为什么会多出来有null的字段值呢?通过分析图上的值得组合会发现是怎么回事儿了,以第三条数据(李欢,null,170)为例:它只是把姓名是【李欢】的分为了一组,而没有考虑【numb】,所以有多出来了第三条数据,也说明了170是怎么来的。其他的也是这样。再回顾一下帮助文档的解释:CUBE 生成的结果集显示了所选列中值的所有组合的聚合, 发现明了了许多。
相关热词:
本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!
本文地址: https://v30.fanwenzhu.com/sql/mssql/2976.shtml
相关文章
热门TAG
win10 ecshop 主机 阿里云 解决 配置 C# C++ 解析 SQL语句 命令 Go语言 方法 CSS3 HTML5 CSS win7 MSSQL 服务器配置 IIS7.5 IIS7 IIS6 IIS CentOS 7 Linux oracle数据库 oracle phpcms discuz discuz教程最新文章
-
SQL基本教程之行转列Pivo
时间:2021-01-20
-
region from hr.Employees union
时间:2021-01-20
-
有时候需要调整用户权限
时间:2021-01-19
-
(但使用 ORDER BY 子句并不
时间:2021-01-19
-
RAND()*10000)insert into Detail
时间:2021-01-19
-
OR 运算符:在两侧的查询
时间:2021-01-19
-
放假之前老大跟我提起了
时间:2021-01-19
-
数据库的运维计策剧本篇
时间:2021-01-19
热门文章
-
4.与聚合函数和 GROUP BY 子句有关的常见错
时间:2021-01-19
-
SQL Server安全(11/11):审核(Auditing)
时间:2021-01-09
-
sqlserver中查询横表变竖表的sql语句简析
时间:2020-12-08
-
SQL Server简单模式下误删除堆表记录恢复方
时间:2020-12-12
-
关于SQL Server查询语句的使用
时间:2020-12-13
-
MSSQL教程_mssql数据库教程_MSSQL基础教程_第
时间:2020-12-13
-
jdbc连接sql server数据库问题分析
时间:2020-12-10
-
详解SQL游标的用法
时间:2020-12-27
-
sql server 关于设置null的一些建议
时间:2020-12-28
-
mssql关于一个表格结构的另外一种显示(表
时间:2020-12-11
