当前位置: 首页 > news >正文

Sql 动态行转列

  SELECT   ID, Name, [Month],auth
  FROM dbo.Test3

数据列表:

1.静态行专列

  Select auth, 
        MAX( CASE WHEN [Month] = '一月' then Name else null end) 一月,
        MAX( CASE WHEN [Month] = '二月' then Name else null end) 二月,
        MAX( CASE WHEN [Month] = '三月' then Name else null end) 三月,
        MAX( CASE WHEN [Month] = '四月' then Name else null end) 四月,
        MAX( CASE WHEN [Month] = '五月' then Name else null end) 五月,
        MAX( CASE WHEN [Month] = '六月' then Name else null end) 六月,
        MAX( CASE WHEN [Month] = '七月' then Name else null end) 七月,
        MAX( CASE WHEN [Month] = '八月' then Name else null end) 八月,
        MAX( CASE WHEN [Month] = '九月' then Name else null end) 九月,
        MAX( CASE WHEN [Month] = '十月' then Name else null end) 十月,
        MAX( CASE WHEN [Month] = '十一月' then Name else null end) 十一月,
        MAX( CASE WHEN [Month] = '十二月' then Name else null end) 十二月                
From dbo.Test3
Group By auth

2.利用PIVOT函数

SELECT auth, 一月, 二月, 三月, 四月 , 五月, 六月 ,七月, 八月 ,九月, 十月 ,十一月, 十二月 
     FROM (SELECT auth, [Month], Name FROM dbo.Test3) AS SourceTable  
PIVOT  
(  
  MAX(Name)  
  FOR [Month] IN (一月, 二月, 三月, 四月 , 五月, 六月 ,七月, 八月 ,九月, 十月 ,十一月, 十二月 )  
) AS PivotTable;

3.利用PIVOT,高效动态行转列 (参考上面,只要生成动态列塞进去就行了)


DECLARE @columns NVARCHAR(MAX) = '';  
  
-- 动态生成列名  
SELECT @columns +=  '' + [Month] + ','  
FROM dbo.Test3;
-- 去除最后一个逗号  
SET @columns = LEFT(@columns, LEN(@columns) - 1);   
PRINT(@columns)
  
-- 构建动态 SQL 查询  
DECLARE @sql NVARCHAR(MAX) = '  
SELECT auth, ' + @columns + '  
FROM   
(  
  SELECT auth, [Month], Name FROM dbo.Test3 
) AS SourceTable  
PIVOT  
(  
    MAX(Name)  
    FOR [Month] IN (' + @columns + ')  
) AS PivotTable;';  
  
-- 执行动态 SQL 查询
 
PRINT(@sql)  
EXECUTE(@sql);

结果:

http://www.lryc.cn/news/268117.html

相关文章:

  • 记录 App webview加载h5页面有上传图片,应用商店审核必须加授权提示问题的解决方案
  • Stable Diffusion模型原理
  • 【Android 13】使用Android Studio调试系统应用之Settings移植(二):构建settings app项目目录
  • w16php系列之基础数组
  • 【C语言】指针详解(四)
  • 算法leetcode|94. 二叉树的中序遍历(多语言实现)
  • 3.[BUUCTF HCTF 2018]WarmUp1
  • rocky linux9 安装go 即接下去
  • NLP中的嵌入层
  • MongoDB文档操作
  • 解决谷歌浏览器下CSS设置字体小于12px无效办法,关于如何在chrome里实现小于12px的文字。
  • springboot(ssm智慧校园之家长子系统 智慧校园系统Java系统
  • RM3100 stm32驱动(硬件i2c)
  • 视觉学习(7) —— 接收数据和发送数据以及全局变量和浮点数
  • leetcode 1576. 替换所有的问号(easy)(优质解法)
  • Advanced IP Scanner - 网络扫描器
  • 搜索百度百科官方创建入口,怎么创建更新公司的百度百科词条呢?
  • 大数据与人工智能|全面数字化战略与企业数字化转型(第1节 )
  • 【四】【C语言\动态规划】地下城游戏、按摩师、打家劫舍 II,三道题目深度解析
  • 【大数据存储与处理】开卷考试总复习笔记
  • HTML 实操试题(一)
  • 创龙瑞芯微RK3568设备树1(修改设备树GPIO和串口)
  • R语言【dplyr】——filter保留符合筛选条件的行,以数据的行为单位,创建子集
  • 几种串口扩展电路
  • 实战10 角色管理
  • Lua的底层原理与C#交互原理浅析【更新中】
  • 鸿蒙项目二—— 注册和登录
  • Dijkstra(迪杰斯特拉)算法总结
  • 设计模式?!
  • Pytorch项目,肺癌检测项目之三