首页 - 数据库 - SQL Server

sqlServer中 分类报表sql技巧 ,很实用

发布时间: 2007-04-19 05:04    作者: 未知    来源: 未知    浏览:    评论


有表 tableA 如下:-----------------------------------------------------id,    type ,   countNumber ,   countDate1 A 10  2005-02-01 21:23:342 B 8  2005-02-01 21:23:343 C 5  2005-02-01 21:23:344 B 4  2005-02-01 11:23:345 C 5  2005-02-01 22:23:346 A 11  2005-02-02 12:23:347 B 9  2005-02-02 14:23:348 C 8  2005-02-02 17:23:349 A 15  2005-02-02 19:23:3410 C 6  2005-02-02 04:23:3411 A 7  2005-02-03 1:23:3412 B 11  2005-02-03 2:23:3413 C 12  2005-02-03 5:23:34.......................

想要用一条语句生成如下的报表

日期   类型A 类型B 类型C 2005-02-01   10 12 10  2005-02-02   26 9 14  2005-02-03   7 11 12 

我用的是如下的sql语句:

SELECT  a.DATEFMT ,(select sum(*) from tableA where type='A' and convert(char(10),countDate,20)= a.DATEFMT) typeA ,(select sum(*) from tableA where type='B' and convert(char(10),countDate,20)= a.DATEFMT) typeB ,(select sum(*) from tableA where type='C' and convert(char(10),countDate,20)= a.DATEFMT) typeC

FROM ( SELECT convert(char(10),countDate,20) DATEFMT FROM tableA GROUP BY convert(char(10),countDate,20)) a

但是这条语句在sqlserver 上执行起来特别的慢,要很久(20多秒),tabelA 中有9万条数据. 而我在mySql(表中有2万条数据)上执行就快很多!

后来在论坛上看到高手这样写

select convert(char(10),countDate,20),typeA=sum(case type when A then CountNumber else 0 end),typeB=sum(case type when B then CountNumber else 0 end),typeC=sum(case type when C then CountNumber else 0 end)From tableAgroup by convert(char(10),countDate,20)

只用 1秒 不到!  唉! 厉害厉害!

TAG

Smile Big Smile Surprise Stick out tongue Wink Sad Tongue Tied Indifferent Crying Embarrassed Cool Angry Angel Devil [8-|] [:#] [:-*] [:^)] [<:o)] [|-)] Yes Beer Left Hug Music Star Time Snail Pizza Automobile Umbrella Computer Storm [mo] [8o|] [^o)] [+o(] [*-)] [8-)] Coffee No Drinks [Z] Right Hug Cake Broken Heart Gift Wilted Flower Movie Dog Idea Sleep Email Travel Paradise
呢称:

加粗 斜体 下划线 链接 图片 代码 邮件地址 引用 列表

最多只能输入100个字符

Tags

SQL 数据库 asp.net C# XML 控件 .NET教程 程序 事件 数据 安全 代码 Server 客户端 验证 数据库专栏 接口 文件 Oracle DataSet 函数 DataGrid 问题 .net return C#语言 JavaScript 服务 IIS 对象 语句 windows 继承 时间 web.config 设计 开发 参数 变量 解决 字符 ADO.net 环境 VB.Net语言 web 异常 工具 服务器 计算 实例 OLEDB Application VB Word WebService insert asp net 安装 记录

精华推荐

更多

精品下载

更多