zoukankan      html  css  js  c++  java
  • 交叉报表处理实例

    两种比较特殊的交叉数据报表处理

    --示例数据:
    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

  • 相关阅读:
    解决 minwidth 在 IE6 中无效的方法
    SmallSlider 图片轮播插件
    css li中a的高端与li的高端不一致,解决方案
    为什么height:5px在IE6里显示不正常?
    命令提示符下不能输入中文
    Sql中日期差 Sql中 DateDiff Sql 中时间差
    20100420 18:17 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\aspnet_state\Parameters
    多个表结果的并列显示
    linux系统下载地址
    VMware中Shared Folders(共享文件夹)的配置
  • 原文地址:https://www.cnblogs.com/accumulater/p/6097711.html
Copyright © 2011-2022 走看看