SqlServer-ROLLUP 喜欢ヅ旅行 2022-06-02 02:36 168阅读 0赞 在生成包含小记和合计的报表时,ROLLUP运算符很有用,ROLLUP运算符生成的结果集类似于CUBE运算符所生成的结果集. ROLLUP和CUBE的区别在于: 1. cube生成的结果集显示了所选列的所有组合的聚合 2. rollup生成的结果集显示了所选列中值的某一个层次结构的聚合 示例: Sql: With rollup: select case when(grouping(sex)=1) then '合计' else sex end, case when(grouping(sclass)=1) then '合计' else sclass end, sum(score) '合计' from student group by sex,sclass with rollup ![clip_image002.jpg][] With cube select case when(grouping(sex)=1) then '小记' else sex end as 性别, case when(grouping(sclass)=1) then '小记' else sclass end as 班级, sum(score) from student group by sex,sclass with cube ![clip_image004.jpg][] 区别解释: 1. cube操作为所选的列的所有组合做了汇总, 男/2,男/3,男/小记,女/2,女/3,女/小记,小记/小记,小记/2,小记/3 2. rollup操作并不针对多列中的所有可能进行汇总,而是以左边的列为主,列出右边的所有可能,然后汇总,不会针对右边的列,将左边列的所有汇总可能计算出来. 优点: 1. rollup返回单个结果集,而compute by返回多个结果集,多个结果集会增加代码的复杂性 2. rollup可以在服务器游标中使用,compute by不可以 3. rollup比compute by 执行起来更加高效 通过排序,可以实现系统想要的效果, 可以将小记汇总放在最上面,也可以将小记汇总放在各个分组之上. 例如: select case when(grouping(sex)=1) then '合计' else sex end, case when(grouping(sclass)=1) then '合计' else sclass end, sum(score) '合计' from student group by sex,sclass with rollup order by grouping(sex) desc,grouping(sclass) desc,sex ![clip_image006.jpg][] select case when(grouping(sex)=1) then '合计' else sex end, case when(grouping(sclass)=1) then '合计' else sclass end, sum(score) '合计' from student group by sex,sclass with rollup order by grouping(sex) desc,sex,grouping(sclass) desc ![clip_image008.jpg][] 出处: [http://www.cnblogs.com/oneword/archive/2009/04/28/1445201.html][http_www.cnblogs.com_oneword_archive_2009_04_28_1445201.html] [clip_image002.jpg]: /images/20220602/8c29a2f66194402fb4b4a379b375e094.png [clip_image004.jpg]: /images/20220602/4c8992baf0824b858bffcf97536f9b8c.png [clip_image006.jpg]: /images/20220602/057302575a074990a13141fd44c926d4.png [clip_image008.jpg]: /images/20220602/ae73f58c4a354cce91ce51c97f1b8184.png [http_www.cnblogs.com_oneword_archive_2009_04_28_1445201.html]: http://www.cnblogs.com/oneword/archive/2009/04/28/1445201.html
还没有评论,来说两句吧...