取消透视的存储过程
Stored procedure to unpivot
我有一个 table 包含这些列:
surname name birthdate id_doc role 01 02 ... 50
Vardy Jack 19870215 1234 'emp' 20200110 20200527 20200610
其中 01 到 50 的字段是日期。我需要这样的 table:
surname name birthdate id_doc role title_code data
Vardy Jack 19870215 1234 'emp' 01 20200110
Vardy Jack 19870215 1234 'emp' 02 20200527
....
其中title code应该是从01到50的列名,data应该是mytable
中该列的值
我通过查看较早的问题来完成此存储过程:
CREATE PROCEDURE proc
AS
BEGIN
DECLARE @UnpivotList NVARCHAR(MAX) = N'';
SELECT @UnpivotList = CONCAT(@UnpivotList, ',(''', c.name, ''', fe.', c.name, ')')
FROM
sys.columns c
WHERE
c.object_id = OBJECT_ID('mytable')
AND c.column_id > 5;
DECLARE @sql NVARCHAR(MAX) = CONCAT(N'
SELECT
fe.surname,
fe.name,
fe.birthdate,
fe.id_doc,
fe.role,
ul.title_code,
ul.Data
FROM
mytable fe
CROSS APPLY ( VALUES ', STUFF(@UnpivotList, 1, 1, ''), N') ul (title_code, Data)');
EXEC sys.sp_executesql @sql;
END
但我在 '.01'
附近遇到语法错误。有人可以帮我吗?
问题出在列名上:因为它们以数字开头,所以您需要引用标识符 - 在 SQL 服务器中,您需要使用方括号。您可以在第一个查询中解决这个问题。
SELECT @UnpivotList = CONCAT(@UnpivotList, ',(''', c.name, ''', fe.[', c.name, '])')
FROM sys.columns c --^ here ^ --
WHERE
c.object_id = OBJECT_ID('mytable')
AND c.column_id > 5;
我有一个 table 包含这些列:
surname name birthdate id_doc role 01 02 ... 50
Vardy Jack 19870215 1234 'emp' 20200110 20200527 20200610
其中 01 到 50 的字段是日期。我需要这样的 table:
surname name birthdate id_doc role title_code data
Vardy Jack 19870215 1234 'emp' 01 20200110
Vardy Jack 19870215 1234 'emp' 02 20200527
....
其中title code应该是从01到50的列名,data应该是mytable
中该列的值我通过查看较早的问题来完成此存储过程:
CREATE PROCEDURE proc
AS
BEGIN
DECLARE @UnpivotList NVARCHAR(MAX) = N'';
SELECT @UnpivotList = CONCAT(@UnpivotList, ',(''', c.name, ''', fe.', c.name, ')')
FROM
sys.columns c
WHERE
c.object_id = OBJECT_ID('mytable')
AND c.column_id > 5;
DECLARE @sql NVARCHAR(MAX) = CONCAT(N'
SELECT
fe.surname,
fe.name,
fe.birthdate,
fe.id_doc,
fe.role,
ul.title_code,
ul.Data
FROM
mytable fe
CROSS APPLY ( VALUES ', STUFF(@UnpivotList, 1, 1, ''), N') ul (title_code, Data)');
EXEC sys.sp_executesql @sql;
END
但我在 '.01'
附近遇到语法错误。有人可以帮我吗?
问题出在列名上:因为它们以数字开头,所以您需要引用标识符 - 在 SQL 服务器中,您需要使用方括号。您可以在第一个查询中解决这个问题。
SELECT @UnpivotList = CONCAT(@UnpivotList, ',(''', c.name, ''', fe.[', c.name, '])')
FROM sys.columns c --^ here ^ --
WHERE
c.object_id = OBJECT_ID('mytable')
AND c.column_id > 5;