首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > asp.net >

比较难实现的有关问题,高手都进来

2012-03-24 
比较难实现的问题,高手都进来!有表class(classid,classname(产品类型))还有表goods(id,classid,sale(0代表

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



*/


/*
--填充 部分数据

INSERT INTO StuSources
SELECT '001 ', '张三 ', '语文 ',81
UNION SELECT '001 ', '张三 ', '数学 ',71
UNION SELECT '001 ', '张三 ', '历史 ',71
UNION SELECT '002 ', '李四 ', '语文 ',82
UNION SELECT '002 ', '李四 ', '数学 ',72
UNION SELECT '002 ', '李四 ', '历史 ',72

*/

/*
-- 一般的直接查询

SELECT * FROM StuSources

-- 结果
StuID StuName KeCheng ChengJi
001 张三 历史 71.0
001 张三 数学 71.0
001 张三 语文 81.0
002 李四 历史 72.0
002 李四 数学 72.0
002 李四 语文 82.0

*/

/*
-- Sql 2000 下 行列转换

SELECT StuName,
'语文 ' = Sum(Case KeCheng WHEN '语文 ' THEN ChengJi ELSE 0 END ) ,
'数学 ' = Sum(Case KeCheng WHEN '数学 ' THEN ChengJi ELSE 0 END ),
'历史 ' = Sum(Case KeCheng WHEN '历史 ' THEN ChengJi ELSE 0 END )
FROM StuSources
GROUP BY StuName

-- 结果
StuName 语文 数学 历史
李四 82.0 72.0 72.0
张三 81.0 71.0 71.0

*/

/*
-- Sql 2005 下 PIVOT

SELECT StuName,[语文] AS '语文 ',
[数学] AS '数学 ',[历史] AS '历史 '
FROM StuSources s
PIVOT (SUM (ChengJi) FOR KeCheng IN ([语文],[数学],[历史]) )AS pvt

*/


[解决办法]
可以用StringBuilder拼HTML。遍历DataTable填充自己的Table

热点排行