数据库

本类阅读TOP10

·SQL语句导入导出大全
·SQL Server日期计算
·SQL语句导入导出大全
·SQL to Excel 的应用
·Oracle中password file的作用及说明
·MS SQLServer OLEDB分布式事务无法启动的一般解决方案
·sqlserver2000数据库置疑的解决方法
·一个比较实用的大数据量分页存储过程
·如何在正运行 SQL Server 7.0 的服务器之间传输登录和密码
·SQL中两台服务器间使用连接服务器

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
sqlServer中 分类报表sql技巧 ,很实用

作者:未知 来源:月光软件站 加入时间:2005-5-13 月光软件站

有表 tableA 如下:
-----------------------------------------------------
id,    type ,   countNumber ,   countDate
1 A 10  2005-02-01 21:23:34
2 B 8  2005-02-01 21:23:34
3 C 5  2005-02-01 21:23:34
4 B 4  2005-02-01 11:23:34
5 C 5  2005-02-01 22:23:34
6 A 11  2005-02-02 12:23:34
7 B 9  2005-02-02 14:23:34
8 C 8  2005-02-02 17:23:34
9 A 15  2005-02-02 19:23:34
10 C 6  2005-02-02 04:23:34
11 A 7  2005-02-03 1:23:34
12 B 11  2005-02-03 2:23:34
13 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 tableA
group by convert(char(10),countDate,20)

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




相关文章

相关软件