比较难实现的问题,高手都进来!
有表 class(classid,classname(产品类型)) 还有表goods(id,classid,sale(0代表销售,1代表进货),count(数字),date) 怎么样实现这样的效果
classname1 classname2 classname3 classname4 classname5
-------------------------------------
date1 销售 count count count count count
进货 count count count count count
date2 销售 count count count count count
进货 count count count count count
date3 销售 count count count count count
进货 count count count count count
--------------------------------------
进货合计 count count count count count
销售合计 count count count count count
总库存 count count count count count
------解决方案--------------------如果是用report services,那矩阵表就是了.
如果是写sql,比较麻烦哈.
以前用informix-4gl的写过,没在sql server里写过
------解决方案--------------------参考,
交叉表的简单实现1:使用存储过程
http://www.cnblogs.com/Jinglecat/archive/2007/05/23/756427.html
SQL 2k5 直接支持 PIVOT 运算
------解决方案--------------------http://blog.csdn.net/sendling/archive/2007/07/08/1683077.aspx
请先参考这个
SQL2000 和 SQL2005下行列转换示例
以下2000调试过
SQL2000 和 SQL2005 下行列转换示例
1.创建 学生成绩表
2.填充 部分数据
3.一般的直接查询
4.Sql 2000 下 行列转换
5.Sql 2005 下 PIVOT
------------
/*
--创建 学生成绩表
CREATE TABLE [StuSources] (
[StuID] [char] (10) COLLATE Chinese_PRC_CI_AS NOT NULL ,
[StuName] [char] (10) COLLATE Chinese_PRC_CI_AS NOT NULL ,
[KeCheng] [char] (10) COLLATE Chinese_PRC_CI_AS NOT NULL ,
[ChengJi] [float] NOT NULL
) ON [PRIMARY]