SQL SERVER特殊行转列案列一则

时间:2021-11-15 23:18:25

今天有个同事找我,他说他有个需求,需要进行行转列,但是又跟一般的行转列有些区别,具体需求如下所说,需要将表1的数据转换为表2的显示格式.

SQL SERVER特殊行转列案列一则

我想了一下,给出了一个解决方法,具体如下所示(先给出测试数据)

INSERT INTO TEST 

SELECT 1,    1,    '定型名称',    '预定型'           UNION ALL

SELECT 1,    2,    '进布方式',    '调平'             UNION ALL

SELECT 1,    3,    '21米长定型机开机速度',    '25'    UNION ALL

SELECT 1,    4,    '烘箱温度',    '195'             UNION ALL

SELECT 1,    5,    '门幅(CM)',    '200-210-210'     UNION ALL

SELECT 2,    1,    '过软',    'na'                  UNION ALL

SELECT 2,    2,    '调平',    'na'                  UNION ALL

SELECT 2,    3,    '25',    '+/-0.5'                UNION ALL

SELECT 2,    4,    '150',    '+/-5℃头尾烘箱除外'   UNION ALL

SELECT 2,    5,    '188-198-198',    '+/-3'

实现其功能的SQL语句如下所示

WITH T

AS

(

SELECT NO, ROW_NUMBER() OVER (PARTITION  BY NO ORDER BY STEP) AS ROWID, NAME, VAlUE FROM TEST

) 

SELECT NO,  MAX(NAME) AS NAME, MAX(VALUE) AS VALUE, MAX(NAME2) AS NAME2 , MAX(VALUE2) AS VALUE2

FROM

(

SELECT NO, NAME AS NAME, VALUE AS VALUE, NULL AS NAME2, NULL AS VALUE2 FROM T WHERE ROWID =1

UNION ALL

SELECT NO, NULL AS NAME ,NULL AS VALUE, NAME AS NAME2, VALUE AS VALUE2 FROM T WHERE ROWID =2

) TT

GROUP BY NO

SQL SERVER特殊行转列案列一则

但是这样有一个弊端就是同一NO的记录不定(不知道有多少条记录),那么上面SQL语句就不知道怎么写了,好在这个需求每个NO最多只有四条记录,所以可以写成下面. 如果记录数再多的话,这个SQL语句就写的很纠结。暂时也没有想到更好的解决方法。

WITH T

AS

(

SELECT NO, ROW_NUMBER() OVER (PARTITION  BY NO ORDER BY STEP) AS ROWID, NAME, VAlUE FROM TEST

) 

SELECT NO, MAX(NAME)  AS NAME  , MAX(VALUE)  AS VALUE 

   , MAX(NAME2) AS NAME2 , MAX(VALUE2) AS VALUE2

   , MAX(NAME3) AS NAME3 , MAX(VALUE3) AS VALUE3

   , MAX(NAME4) AS NAME4 , MAX(VALUE4) AS VALUE4

FROM

(

SELECT NO, NAME AS NAME , VALUE AS VALUE  , 

     NULL AS NAME2, NULL  AS VALUE2 ,

     NULL AS NAME3, NULL  AS VALUE3 ,

     NULL AS NAME4, NULL  AS VALUE4

FROM T WHERE ROWID =1

UNION ALL

SELECT NO, NULL AS NAME ,  NULL AS VALUE  , 

     NAME AS NAME2, VALUE AS VALUE2 ,

     NULL AS NAME3, NULL  AS VALUE3 ,

     NULL AS NAME3, NULL  AS VALUE4

FROM T WHERE ROWID =2

UNION ALL

SELECT NO, NULL AS NAME , NULL  AS VALUE  , 

     NULL AS NAME2, NULL  AS VALUE2 ,

     NAME AS NAME3, VALUE AS VALUE3 ,

     NULL AS NAME4, NULL  AS VALUE4

FROM T WHERE ROWID =3

UNION ALL

SELECT NO, NULL AS NAME , NULL  AS VALUE  , 

     NULL AS NAME2, NULL  AS VALUE2 ,

     NULL AS NAME3, NULL  AS VALUE3 ,

     NAME AS NAME4, VALUE AS VALUE4 

FROM T WHERE ROWID =4

) TT

GROUP BY NO

SQL SERVER特殊行转列案列一则的更多相关文章

  1. Expression构建DataTable to Entity 映射委托 sqlserver 数据库里面金额类型为什么不建议用float,实例告诉你为什么不能。 sql server 多行数据合并成一列 C# 字符串大写转小写,小写转大写,数字保留,其他除外 从0开始用U盘制作启动盘装Windows10系统(联想R720笔记本)并永久激活方法 纯CSS打造淘宝导航菜单栏 C# Winform

    Expression构建DataTable to Entity 映射委托   1 namespace Echofool.Utility.Common { 2 using System; 3 using ...

  2. sql server 多行数据合并成一列

    首先是源数据: ),cip.CheckIn_StartTime, )),cip.CheckIn_EndTime, )),cip.Rental_Price)) as content from Check ...

  3. 在SQL Server 2014里可更新的列存储索引 (Updateable Column Store Indexes)

    传统的关系数据库服务引擎往往并不是对超大量数据进行分析计算的最佳平台,为此,SQL Server中开发了分析服务引擎去对大笔数据进行分析计算.当然,对于数据的存放平台SQL Server数据库引擎而言 ...

  4. 向SQL Server 现有表中添加新列并添加描述.

    注: sql server 2005 及以上支持. 版本估计是不支持(工作环境2005,2008). 工作需要, 需要向SQL Server 现有表中添加新列并添加描述. 从而有个如下存储过程. (先 ...

  5. 第十篇 SQL Server安全行级安全

    本篇文章是SQL Server安全系列的第十篇,详细内容请参考原文. 不像一些其他industrial-strength数据库服务,SQL Server缺乏一个内置保护个别数据记录的机制,称为行级安全 ...

  6. 【译】第十篇 SQL Server安全行级安全

    本篇文章是SQL Server安全系列的第十篇,详细内容请参考原文. 不像一些其他industrial-strength数据库服务,SQL Server缺乏一个内置保护个别数据记录的机制,称为行级安全 ...

  7. MSSQL-Scripter,一个新的生成T-SQL脚本的SQL Server命令行工具

    这里向大家介绍一个新的生成T-SQL脚本的SQL Server命令行工具:mssql-scripter.它支持在SQL Server.Azure SQL DB以及Azure SQL DW中为数据库生成 ...

  8. SQL Server 动态行转列(参数化表名、分组列、行转列字段、字段值)

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 实现代码(SQL Codes) 方法一:使用拼接SQL,静态列字段: 方法二:使用拼接SQL, ...

  9. SQL Server 动态行转列(轉載)

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 实现代码(SQL Codes) 方法一:使用拼接SQL,静态列字段; 方法二:使用拼接SQL, ...

  10. SQL Server pivot 行转列遇到的问题

    前段时间开发系统时,有个功能是动态加载列,于是就使用了SQL Server自带的PIVOT函数进行行转列,开始用的非常溜,效果非常好.但是提交测试后问题来了,测试添加的列名中包含空格,然后就杯具了,功 ...

随机推荐

  1. java终端获取输入

    上一篇博客已经介绍了System.in这个输入流这次谈谈java如何获取终端(控制台)的输入 (1)BufferedReader JDK 1.4 及以下的版本中要想从控制台中输入数据只有一种办法,即使 ...

  2. Python 元组知识点

    1.元组是一个有序的集合,2.元组和列表一样可以使用索引.切片来取值.3.创建元组后不能在原地进行修改替换等操作.4.元组支持嵌套,可以包含列表.字典和不同元组.5.元组支持一般序列的操作,例如:+. ...

  3. sencha touch 开发准备

    这是本人第一次写博客教程,没什么经验,文笔也不是很好,写这教程一方面为了巩固自己这段时间的学习成果,一方面帮助大家解决问题,欢迎大家多提建议,指出问题.接下来我们就开始我们的sencha touch开 ...

  4. mydate97时间控件最大值最小值限制及Javascript日期判断大小

    <script language="javascript" type="text/javascript" src="<%=basePath ...

  5. 信息传递--NOIP2015 day1 T2--暴力

    这道题我用了判联通量加暴力,但联通量判炸了....然后从code[VS]上看到个不错的代码,就拿来了^_^... 基本思路是去掉环外的点,然后走每一个联通块. #include <iostrea ...

  6. jQuery免费资料

     JQvery免豆.pdf       jQuery实战之仿flash跳动的按钮效果[源码]http://down.51cto.com/data/188600JQuery 1.4.2 手册简体中文版h ...

  7. linux下查找文件和文件内容

    find /xxx -name "*" | xargs grep "某内容" /xxx表示路径,"*"表示在含有某关键字名字下的文件中查找, ...

  8. 【转帖】C&num; DllImport 系统调用使用详解 托管代码的介绍 EntryPoint的使用

    1      DLLImport的使用 using System; using System.Runtime.InteropServices; //命名空间 class Example { //用Dl ...

  9. SPM HW1 A project

    项目分析 --民航航班异常轨迹可视分析 最近完成的一个项目是一个可视化大作业--民航航班异常轨迹可视分析.要求利用已给的8G飞机的飞行记录数据,将飞机的飞行轨迹在浏览器中进行飞行轨迹高维可视化以及对异 ...

  10. centos perl&colon; symbol lookup error&colon; &sol;usr&sol;local&sol;lib64&sol;perl5&sol;auto&sol;DBD&sol;mysql&sol;mysql&period;so&colon; undefined symbol&colon; mysql&lowbar;init

    之前在安装天兔数据库监控工具lepus的时候,运行时一直报perl: symbol lookup error: /usr/local/lib64/perl5/auto/DBD/mysql/mysql. ...