CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
IBM Rational 系统开发最佳实践工具包 WebSphere MQ 最佳实践 TOP 15
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  MS-SQL Server >  基础类

交叉报表

楼主zhaowenbo(zhaowenbo)2006-03-09 10:01:02 在 MS-SQL Server / 基础类 提问

表结构:   name(char),mony(float),date(char)  
  现在要统计每个人每月的消费次数  
  查询结果如:name,   1月,2月,3月.......12月消费次数  
                          张三,   9,0..................  
                          李四,0,2,3,4..............  
   
  高手们能否帮我看看...谢谢  
   
  问题点数:20、回复次数:3Top

1 楼scmail81(琳·风の狼(修罗))回复于 2006-03-09 10:28:09 得分 20

declare   @T_SQL   varchar(8000)  
  select   @T_SQL=@T_SQL   +   'sum(case   when   date='''   +   date   +   '''   then   mony   else   0   end)   as   '''   +   date   +   ''','   from   (select   distinct   date   from   表   )   T  
  set   @T_SQL='select   name,'   +     left(@T_SQL,len(@T_SQL)-1)   +   '   from   表   group   by   name'Top

2 楼scmail81(琳·风の狼(修罗))回复于 2006-03-09 10:29:14 得分 0

限于   date(char)   存储数据的格式为  
  1月  
  2月  
  3月  
  ...Top

3 楼scmail81(琳·风の狼(修罗))回复于 2006-03-09 10:30:19 得分 0

declare   @T_SQL   varchar(8000)  
  select   @T_SQL=@T_SQL   +   '   sum(case   when   date='''   +   date   +   '''   then   mony   else   0   end)   as   '''   +   date   +   ''','   from   (select   distinct   date   from   表   )   T  
  set   @T_SQL='select   name,'   +     left(@T_SQL,len(@T_SQL)-1)   +   '   from   表   group   by   name'Top

相关问题

  • crosstab交叉报表
  • 关于交叉表报表
  • 简单问题。交叉报表问题
  • 动态创建交叉报表。
  • 求助!!!交叉报表的问题
  • 交叉报表如何设计?
  • 关于交叉报表分页打印?
  • 关于交叉报表的问题
  • 关于交叉报表问题,郁闷.
  • 怎样生成交叉报表

关键词

  • date
  • sql
  • mony
  • char
  • select

得分解答快速导航

  • 帖主:zhaowenbo
  • scmail81

相关链接

  • SQL Server类图书

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo