Sql学习第三天——SQL 关于with ties介绍

2020-03-13 作者:计算机教程   |   浏览(141)

关于with cube ,with rollup 和 grouping

关于with ties

通过查看sql 2005的帮助文档找到了CUBE 和 ROLLUP 之间的具体区别

对于with ties一般是和Top , order by相结合使用的,会查询出最后一条数据额外的返回值返回了前面n个记录,但是n 1…n k条记录和排序后的第n条记录的参数值相同,则n 1、…、n k也返回。n 1、…、n k就是额外的返回值)。

CUBE 生成的结果集显示了所选列中值的所有组合的聚合。ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合。

实验:

再看看对grouping的解释:

实验用表:复制代码 代码如下:CREATE TABLE [dbo].[PeopleInfo]( [id] [int] IDENTITY(1,1) NOT NULL, [name] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL, [numb] [nchar](10) COLLATE Chinese_PRC_CI_AS NOT NULL, [phone] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL ) ON [PRIMARY]向表中插入数据:复制代码 代码如下:insert into peopleinfo([name],numb,phone) values ('李欢','3223','1365255') insert into peopleinfo([name],numb,phone) values ('李欢','322123','1') insert into peopleinfo([name],numb,phone) values ('李名','3213112352','13152') insert into peopleinfo([name],numb,phone) values ('李名','32132312','13342563')查看插入的全部数据:复制代码 代码如下:select * from dbo.PeopleInfo结果图:

当行由 CUBE 或 ROLLUP 运算符添加时,该函数将导致附加列的输出值为 1;当行不由 CUBE 或 ROLLUP 运算符添加时,该函数将导致附加列的输出值为 0。

操作步骤1:不用with ties

仅在与包含 CUBE 或 ROLLUP 运算符的 GROUP BY 子句相关联的选择列表中才允许分组。

代码:复制代码 代码如下:select top 3 * from peopleinfo order by [name] desc结果如图:

当看到以上的解释肯定非常的模糊,不知所云和不知道该怎样用,下面通过实例操作来体验一下:

操作步骤2:用with ties

先建表:复制代码 代码如下:CREATE TABLE [dbo].[PeopleInfo]( [id] [int] IDENTITY(1,1) NOT NULL, [name] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL, [numb] [nchar](10) COLLATE Chinese_PRC_CI_AS NOT NULL, [phone] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL, [FenShu] [int] NULL ) ON [PRIMARY]向表插入数据:复制代码 代码如下:insert into peopleinfo([name],numb,phone,fenshu) values ('李欢','3223','1365255',80) insert into peopleinfo([name],numb,phone,fenshu) values ('李欢','322123','1',90) insert into peopleinfo([name],numb,phone,fenshu) values ('李名','3213112352','13152',56) insert into peopleinfo([name],numb,phone,fenshu) values ('李名','32132312','13342563',60) insert into peopleinfo([name],numb,phone,fenshu) values ('王华','3223','1365255',80)查询出插入的全部数据:复制代码 代码如下:select * from dbo.PeopleInfo结果如图:

代码:复制代码 代码如下:select top 3 with ties * from peopleinfo order by [name] desc结果如图:

操作一:先试试:1, 查询所有数据;2,用group by 查询所有数据;3,用with cube。这三种情况的比较

如果with ties不与top和order by结合使用的错误示范:

SQL语句如下:复制代码 代码如下:select * from dbo.PeopleInfo --1, 查询所有数据; select [name],numb,sum(fenshu) from dbo.PeopleInfo group by [name],numb --2,用group by 查询所有数据; select [name],numb,sum(fenshu) from dbo.PeopleInfo group by [name],numb with cube --3,用with cube。这三种情况的比较结果如图:

操作步骤1:不与order by结合使用,只和top结合使用:

结果分析:

代码:复制代码 代码如下:select top 3 with ties * from peopleinfo错误消息如图:

用第三种(用with cube)为什么会多出来有null的字段值呢?通过分析图上的值得组合会发现是怎么回事儿了,以第三条数据为例:它只是把姓名是的分为了一组,而没有考虑,所以有多出来了第三条数据,也说明了170是怎么来的。其他的也是这样。再回顾一下帮助文档的解释:CUBE 生成的结果集显示了所选列中值的所有组合的聚合, 发现明了了许多。

操作步骤2:不与top结合使用,只和order by结合使用:

操作二:1,用with cube;2,用with rollup 这两种情况的比较**

代码:复制代码 代码如下:select with ties * from peopleinfo order by [name] desc错误消息如图:

本文由www.2003.com发布于计算机教程,转载请注明出处:Sql学习第三天——SQL 关于with ties介绍

关键词: