交叉报表处理实例
来源:互联网 发布:怎么在防火墙打开端口 编辑:程序博客网 时间:2024/05/01 22:17
两种比较特殊的交叉数据报表处理
--示例数据:
CREATE TABLE tb(ID varchar(10),NGNO char(1),QTY int)
INSERT tb SELECT '200505','A',10
UNION ALL SELECT '200505','B',20
UNION ALL SELECT '200505','C',30
UNION ALL SELECT '200506','B',10
UNION ALL SELECT '200506','C',20
UNION ALL SELECT '200506','D',30
UNION ALL SELECT '200506','E',40
GO
交叉数据报表要求1:
按ID列分组,将NGNO列水平显示为多列,但每列由NGNO的大小顺序决定,而不是由NGNO的值决定,对于示例数据,最终的结果要求如下:
ID col1 col2 col3 col4
---------- ------- ------- ------- -------
200505 A(10) B(20) C(30)
200506 B(10) C(20) D(30) E(40)
--实现代码
DECLARE @i varchar(10),@s nvarchar(4000)
SELECT TOP 1 @s='',@I=COUNT(*) FROM tb
GROUP BY ID
ORDER BY COUNT(*) DESC
WHILE @i>0
SELECT @s=N',col'+@i
+N'=ISNULL(MAX(CASE GID WHEN '+@i
+N' THEN QTY END),'''')'+@s,
@i=@i-1
EXEC(N'SELECT ID'+@s+N'
FROM(
SELECT ID,QTY=RTRIM(NGNO)+QUOTENAME(QTY,N''()''),
GID=(SELECT COUNT(DISTINCT NGNO) FROM TB WHERE ID=a.ID AND NGNO<=a.NGNO)
FROM tb a
)a GROUP BY ID')
GO
交叉数据报表要求2:
按ID列分组,将NGNO及QTY列合并显示在一个列中,最终的结果要求如下:
ID Value
---------- -----------------------------------------------
200505 A(10) B(20) C(30)
200506 B(10) C(20) D(30) E(40)
(所影响的行数为 2 行)
--实现处理的函数
CREATE FUNCTION f_Str(@ID varchar(10))
RETURNS varchar(8000)
AS
BEGIN
DECLARE @r varchar(8000)
SET @r=''
SELECT @r=@r+SPACE(8)+RTRIM(NGNO)+QUOTENAME(QTY,'()')
FROM tb
WHERE ID=@ID
RETURN(STUFF(@r,1,8,''))
END
GO
--调用实现查询
SELECT ID,Value=dbo.f_Str(ID) FROM tb GROUP BY ID
GO
原帖地址
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 转:邹建--交叉报表处理实例
- 交叉报表
- smart发布中发现的weblogic/tomcat/resin的兼容性问题以及解决方案
- 专访: Discuz!王炳坤:Discuz!NT定位在差异化
- 孔乙己之四----虚函数(中)
- 由一篇BLOG看多态
- 更关注Google输入法发布对搜索的意义[有下载链接]
- 交叉报表处理实例
- 在SourceForge.net上使用TortoiseCVS上传代码
- Google Blogger 脱离Beta版 与Gmail账户绑定
- 基于win平台的高性能服务器底层通信模型设计(1)
- BOM数据排序及分级显示
- [大图]Linux family tree“族谱”大串烧
- smart1.0稳定版 终于在sourceforge released
- 使用vb调用vba在word中插入图片的代码
- 新闻短评:OpenAjax,WPF,Apollo激战RIA