//这使我写的分组合计
sql:='select DutySection,Male,KnowedMale,Percent1,Female,KnowedFemal,'+
'percent2,case when DutySection = ''共计'' then '''' else Policeman end Policeman,'+
'FillinDate from ('+
'select CASE WHEN (GROUPING(DutySection) = 1) THEN ''共计'' '+
'ELSE ISNULL(DutySection, ''UNKNOWN'') '+
'END AS DutySection,sum(Male) Male,sum(KnowedMale) KnowedMale,'+
'convert(varchar(8),CONVERT(decimal(6,2),avg(percent1)))+''%'' Percent1,'+
'sum(Female) Female,sum(KnowedFemal) KnowedFemal,'+
'convert(varchar(8),CONVERT(decimal(6,2),avg(percent2)))+''%'' percent2,'+
'max(Policeman) Policeman,CASE WHEN (GROUPING(FillinDate) = 1) THEN ''共计'' '+
'ELSE ISNULL(FillinDate, ''UNKNOWN'') '+
'END AS FillinDate from '+
'(select DutySection,Male,KnowedMale,'+
'Case Male when 0 then 0 '+
'else isnull(KnowedMale,0)*100.00 / isnull(Male,1) end percent1,'+
'Female,KnowedFemal,'+
'case Female when 0 then 0 '+
'else isnull(KnowedFemal,0)*100.00 / isnull(Female,1) end percent2,'+
'Policeman,FillinDate from T_AgePhase ) a '+
'group by FillinDate,DutySection with rollup ) b '+
'where FillInDate <> ''共计'' order by FillIndate ';
//这是说明
用 ROLLUP 汇总数据
在生成包含小计和合计的报表时,ROLLUP 运算符很有用。ROLLUP 运算符生成的结果集类似于 CUBE 运算符所生成的结果集。有关更多信息,请参见用 CUBE 汇总数据。
CUBE 和 ROLLUP 之间的区别在于:
CUBE 生成的结果集显示了所选列中值的所有组合的聚合。
ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合。
例如,简单表 Inventory 中包含:
Item Color Quantity
-------------------- -------------------- --------------------------
Table Blue 124
Table Red 223
Chair Blue 101
Chair Red 210
下列查询将生成小计报表:
SELECT CASE WHEN (GROUPING(Item) = 1) THEN 'ALL'
ELSE ISNULL(Item, 'UNKNOWN')
END AS Item,
CASE WHEN (GROUPING(Color) = 1) THEN 'ALL'
ELSE ISNULL(Color, 'UNKNOWN')
END AS Color,
SUM(Quantity) AS QtySum
FROM Inventory
GROUP BY Item, Color WITH ROLLUP
Item Color QtySum
-------------------- -------------------- --------------------------
Chair Blue 101.00
Chair Red 210.00
Chair ALL 311.00
Table Blue 124.00
Table Red 223.00
Table ALL 347.00
ALL ALL 658.00
(7 row(s) affected)
如果查询中的 ROLLUP 关键字更改为 CUBE,那么 CUBE 结果集与上述结果相同,只是在结果集的末尾还会返回下列两行:
ALL Blue 225.00
ALL Red 433.00
CUBE 操作为 Item 和 Color 中值的可能组合生成行。例如,CUBE 不仅报告与 Item 值 Chair 相组合的 Color 值的所有可能组合(Red、Blue 和 Red + Blue),而且报告与 Color 值 Red 相组合的 Item 值的所有可能组合(Chair、Table 和 Chair + Table)。
对于 GROUP BY 子句中右边的列中的每个值,ROLLUP 操作并不报告左边一列(或左边各列)中值的所有可能组合。例如,ROLLUP 并不对每个 Color 值报告 Item 值的所有可能组合。
ROLLUP 操作的结果集具有类似于 COMPUTE BY 所返回结果集的功能;然而,ROLLUP 具有下列优点:
ROLLUP 返回单个结果集;COMPUTE BY 返回多个结果集,而多个结果集会增加应用程序代码的复杂性。
ROLLUP 可以在服务器游标中使用;COMPUTE BY 不可以。
有时,查询优化器为 ROLLUP 生成的执行计划比为 COMPUTE BY 生成的更为高效。