两种比较特殊的交叉数据报表处理
来源:互联网 发布:java 黑板模式 编辑:程序博客网 时间:2024/05/17 00:59
--示例数据:
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="http://www.blog.com.cn/dbo.f_Str(ID) FROM tb GROUP BY ID
GO"
- 两种比较特殊的交叉数据报表处理
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉报表处理实例
- 交叉数据报表
- 动态分组查询
- 网页编程最值得去的十个网站
- 逐月对比的交叉表处理
- Javascript 异常处理
- 日本老人“健脑”忙 市面涌现大量益智游戏
- 两种比较特殊的交叉数据报表处理
- 数据库中实现,字段合并显示
- 先进先出的数据冲销处理
- 短信字符串分拆
- 如果忘记了XP系统密码
- 根据排序定义表排序数据
- 中国分布式计算总站
- 3D游戏编程(五)
- ASP.NET 2.0中将 GridView 导出到 Excel 文件中