SQL如何得到下面的数据?(30分)

  • 主题发起人 主题发起人 vb163
  • 开始时间 开始时间
V

vb163

Unregistered / Unconfirmed
GUEST, unregistred user!
我想用SQL语句查询的结果在DBGRIDEH中显示如下:
日 期 名 称 数 量
06/08/25 AAAAA 10
06/08/25 BBBBB 15
小计: 25
06/08/26 CCCCC 5
06/08/26 AAAAA 10
小计: 15
。。。。。。。。。。。
用SQL语句如何搞定呢,还有是不是要在DBGRID中也要设置什么属性呢?
 
现在SQL是写出来了,怎么显示没有达到我的要求呢?现在查出来的效果如下:
日 期 名 称 数 量
06/08/25 AAAAA 10
06/08/25 BBBBB 15
06/08/26 CCCCC 5
06/08/26 AAAAA 10
。。。。。。。。。。
06/08/25 小计: 25
06/08/26 小计: 15
。。。。。。。。。。。
也就说统计出来的小计全部跑到下边去了~~~怎么能让他在每组下面(分组显示)显示呢?
 
用两个sql,结果union
 
就是用的两个SQL,用UNION关联的,显示出来的效果就是:
日 期 名 称 数 量
06/08/25 AAAAA 10
06/08/25 BBBBB 15
06/08/26 CCCCC 5
06/08/26 AAAAA 10
。。。。。。。。。。
06/08/25 小计: 25
06/08/26 小计: 15
。。。。。。。。。。。
 
还是自己解决了~~~~呵呵[:D][:D]现效果如下:功能已经实现~~~
日 期 名 称 数 量
06/08/25 AAAAA 10
06/08/25 BBBBB 15
小计: 25
06/08/26 CCCCC 5
06/08/26 AAAAA 10
小计: 15
。。。。。。。。。。。
 
我这样的情况是在小计字段做处理,然后排序,让小计总在最后。
 
临时表
用insert into 表1及表1的字段和
再insert into 表2及表2的字段和
 
lz分享一下你的经验呀。呵呵
 
同意楼上的
 
主要还是用两个SQL;第一个SQL查出相关的信息,第二个SQL查出相关信息的合计(SUM)
最后用UNION关联就OK,不过在最后要加个GROUP BY分组才能显示出我上面的效果来~~~
 
//这使我写的分组合计
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 生成的更为高效。
 
楼主:
你可以设法取得一个用友财务的数据库,里边很多关于联合查询的实例,那可是一等一的高手做的。参考之后,你的这个问题就会轻松解决![:)]
 
有个footer属性你研究一下就解决了
 
用不着那么麻烦,我只用SQL就解决了~~~不过代码有点长而已~多谢各位参与~~~
 

Similar threads

后退
顶部