zoukankan      html  css  js  c++  java
  • SQL SERVER列转换行及UNPIVOT

    --***************列传行***************************
    --构建样例表及初始化数据
    IF OBJECT_ID('TB')IS NOT NULL DROP TABLE TB
    GO
    CREATE TABLE TB
    (
         姓名 NVARCHAR(10)
        ,语文 INT
        ,数学 INT
        ,物理 INT
    )
    INSERT INTO TB VALUES(N'张三',74,83,93)
    INSERT INTO TB VALUES(N'李四',74,84,94)

    SELECT * FROM TB WITH(NOLOCK)
    GO
    --SQL SERVER 2000静态SQL
    SELECT 
        * 
    FROM ( 
            SELECT 
                姓名 
               ,N'语文' AS 课程
               ,语文 AS 分数 
            FROM TB 
            UNION ALL

            SELECT 
                姓名 
               ,N'数学' AS 课程
               ,数学 AS 分数 
            FROM TB 
            UNION ALL

            SELECT 
                姓名 
               ,N'物理' AS 课程
               ,物理 AS 分数 
            FROM TB
         ) AS TT 
    ORDER BY TT.姓名
    --SQL SERVER 2000动态SQL
    DECLARE @SQL6 nvarchar(MAX)
    SELECT 
        @SQL6=ISNULL(@SQL6+' 
                        UNION ALL 
    ','')+ N'SELECT 
                           姓名 
                          ,N
    '''+[Name]+ N''' 课程,'+[Name] +N' 分数 FROM TB ' 
                       FROM sys.columns 
                       WHERE 
                           [object_id]=OBJECT_ID('TB')  AND[Name]!=N'姓名'
    SET @SQL6=N'SELECT 
                    * 
                FROM (
    '+@SQL6+N') AS T 
                ORDER BY T.姓名
    '
    PRINT @SQL6

    EXEC(@SQL6) 

    UNPIVOT--列名转换列值,即列转行
    Table_Source
    UNPIVOT
    (

       value_column

       FOR pivot_column
       IN(列名列表)
    )别名

    ----SQL SERVER 2005静态SQLSELECT 
        姓名,分数,课程
    FROM TB 
    UNPIVOT
    (
         分数 FOR 课程 IN 
        (
             语文
            ,数学
            ,物理
        )
    AS T

     ----SQL SERVER 2005动态SQL
    DECLARE @SQL7 NVARCHAR(MAX)
     SELECT @SQL7=ISNULL(@SQL7+',','')+[Name] FROM sys.columns WHERE 
                           [object_id]=OBJECT_ID('TB')  AND[Name]!=N'姓名'
    SET @SQL7= N'SELECT 姓名,分数,课程 FROM TB UNPIVOT( 分数 FOR 课程 IN ('+@SQL7+N')) AS T ORDER BY 姓名'
    PRINT @SQL7
    EXEC SP_EXECUTESQL @SQL7
    /*运行结果:
        姓名  课程  分数
        ---------- -----------
        张三  语文  74
        张三  数学  83
        张三  物理  93
        李四  语文  74
        李四  数学  84
        李四  物理  94
    */
  • 相关阅读:
    flume+kafka (分区实现 默认单分区)
    flume+kafka (分区实现 默认单分区) (二)
    trident 序列号问题
    C#运动控制日志报警记录和操作记录记录查询(SqlLite数据库操作)
    C#运动控制运动暂停思路检测沿信号方法
    C#使用json配置文件方法【读写Json,适合小项目】
    C#NLog日志组件使用
    C#运动控制05实时报警及显示方案
    C#USB扫码枪实现无焦点状态下扫入
    C#运动控制05日志显示(ListView和imageList控件使用)
  • 原文地址:https://www.cnblogs.com/jeriffe/p/1993578.html
Copyright © 2011-2022 走看看