日期:2014-05-18  浏览次数:20507 次

比较难实现的问题,高手都进来!
有表   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]