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