博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第四种行转列
阅读量:6245 次
发布时间:2019-06-22

本文共 2094 字,大约阅读时间需要 6 分钟。

 --动态处理

select A.StuName,A.BZKTypeName,cast(A.BKCODE as varbinary(MAX)) even,

      row_number() over (partition by StuName,BZKTypeName order by getdate()) ID
    into #t1
    from BKLIST A
    --where StuName='林健辉'
 
  declare @sql1 varchar(max)
  declare @sql2 varchar(max)

  declare @id int

  declare @maxid int
  select @maxid=max(id)
    from #t1
  

  set @id=1

  set @sql1=''
  set @sql2=''
  while @id<@maxid
    begin

      set @sql1=@sql1+'['+CAST(@id as varchar(10))+'],'

      set @sql2=@sql2+' case when '+'['+CAST(@id as varchar(10))+']'
        +' IS null then  '''' else CAST('+'['+CAST(@id as varchar(10))+']'
        +' as varchar(100))+'','' end +'
      set @id=@id+1
    end
  set @sql1=@sql1+'['+CAST(@id as varchar(10))+']'

  set @sql2=@sql2+' case when '+'['+CAST(@id as varchar(10))+']'

    +' IS null then  '''' else CAST('+'['+CAST(@id as varchar(10))+']'
    +' as varchar(100)) end '
 
--print @sql1
--print @sql2
 
 
 

  declare @sql varchar(max)

  set @sql='
select StuName,BZKTypeName,LEFT(BKCODE,LEN(BKCODE)-1)   from ( 
SELECT StuName,BZKTypeName,
  
   BKCODE
  FROM ( select *    from #t1
   ) s2  PIVOT ( max(even) FOR ID IN ()) as pvt
 
 )s3

'

  print @sql
  exec( @sql)

 

-------------------------------------------------------------------

--执行的语句

select StuName,BZKTypeName,LEFT(BKCODE,LEN(BKCODE)-1)   from ( 

SELECT StuName,BZKTypeName,
    case when [1] IS null then  '' else CAST([1] as varchar(100))+',' end
    + case when [2] IS null then  '' else CAST([2] as varchar(100))+',' end
    + case when [3] IS null then  '' else CAST([3] as varchar(100))+',' end
    + case when [4] IS null then  '' else CAST([4] as varchar(100))+',' end
    + case when [5] IS null then  '' else CAST([5] as varchar(100)) end
   BKCODE
  FROM ( select *    from #t1
   ) s2  PIVOT ( max(even) FOR ID IN ([1],[2],[3],[4],[5])) as pvt
 
 )s3

 

 

 

 

 

----------------------------------------------------------------------------------------------------------

 --与XML方式的一次对比

 

--xml方式脚本

select B.StuName,B.BZKTypeName,left(NT,len(NT)-1) as evenNew

    from (
          select StuName,BZKTypeName,(
                                      select BKCODE+','
                                        from BKList
                                        where StuName=A.StuName
                                          and BZKTypeName=A.BZKTypeName
                                        order by StuName,BZKTypeName
                                     for
                                      xml path('')
                                     ) as NT
            from BKList A
            group by StuName,BZKTypeName
         ) B
  

转载地址:http://weoia.baihongyu.com/

你可能感兴趣的文章
【C#小知识】C#中一些易混淆概念总结(五)---------深入解析C#继承
查看>>
数据库优化
查看>>
TensorFlow的基本运算01-03
查看>>
Hive-有意思的query
查看>>
SylixOS调试与性能分析技术--内存泄漏检测
查看>>
消息队列-ActiveMQ
查看>>
LoadRunner12使用教程(二)——回放与录制
查看>>
工作收获点
查看>>
PhpStorm Terminal终端无法打开
查看>>
学习笔记TF036:实现Bidirectional LSTM Classifier
查看>>
应用监控预警&服务链路跟踪-Pinpoint介绍
查看>>
前端:后端,我要分手
查看>>
smarty isset 怎样使用
查看>>
用图帮你了解https的原理
查看>>
区块链如何改变AI
查看>>
HTML5/JavaScript UI控件Wijmo Enterprise 2018v2发布
查看>>
工业仪表盘控件Iocomp ActiveX常见问题(2):Visual Basic中的错误
查看>>
Docker下使用selenium+testng实现web自动化
查看>>
当执行npm时遇到的问题
查看>>
JAVA程序员面试30问(附带答案)
查看>>