求一分类汇总的 SQL语句...
1.现有一表如下:
编号,客户名称,名称,型号,数量,单价,总金额,经办人
1 a B C 1 2 2 S
2 a B1 C1 3 3 9 S1
3 b B C 2 3 6 S
1 a B2 C2 1 3 3 S
用分类汇总得如下表
编号 1 客户名称 a
名称,型号,数量,单价,总金额,经办人
B C 1 2 2 S
B2 C2 1 3 3 S
总计: 5
编号 2 客户名称 a
名称,型号,数量,单价,总金额,经办人
B1 C1 3 3 9 S
总计: 9
编号 3 客户名称 b
名称,型号,数量,单价,总金额,经办人
B C 2 3 6 S
总计: 6
怎么实现查询后在StringGrid 显示出来?谢谢
[解决办法]
怎么不用DBGrid?连上查询控件就能显示。
[解决办法]
SELECT 编号,客户名称,名称,型号,数量,单价,总金额,经办人
FROM #A
UNION ALL
SELECT 编号,客户名称,'总计','','','',SUM(总金额),''
FROM #A
GROUP BY 编号,客户名称
ORDER BY 编号,客户名称,名称
[解决办法]
数据集属性 DataSet
数据源属性 DataSouce
DBGrid由于有数据源属性,所以可以很方便的用来显示表。
[解决办法]
SELECT 编号,客户名称,名称,型号,数量,单价,总金额,经办人FROM 你的表1UNION ALLSELECT 编号,客户名称,'总计','','','',SUM(总金额),''FROM 你的表2GROUP BY 编号,客户名称ORDER BY 编号,客户名称,名称
[解决办法]
用 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 生成的更为高效。