我有一个这样的表格“详细信息”:
ID | BookID | Genre
_____________________________________________________
1 | 12 | AB
1 | 05 | AC
2 | 12 | AB
2 | 08 | BB
有什么方法可以将这些行组合成这种格式:
ID | BookID1 | Genre1 | BookID2 | Genre2
_____________________________________________________
1 | 12 | AB | 05 | AC
2 | 12 | AB | 08 | BB
我需要以这样的格式将相应的列添加到存储过程中。
我通常很想包含一些代码或尝试,但目前我一无所知。
不是下面的副本:SQL动态枢轴
第一个区别我没有使用tsql。
第二个区别是桌子的结构不能应用于我的。
我的值而不是将是列标题,它们将生成新的列,例如:
ID | BookID1 | Genre1 | BookID2 | Genre2 | BookID3 | Genre3 | BookID4 | Genre4
1 | 05 | Horror | 12 | Horror | 03 | Drama | |
2 | 05 | Horror | 15 | Advent | 03 | Drama | 112 | RomCom
第三,我无法掌握结构,因为我对数据透视表的了解为零
对于所有有类似案件的人。
下面的链接是一个巨大的帮助:
https://community.spiceworks.com/topic/973727-sql-how-to-convert-multiple-rows-into-single-rows-with-more-columns
尝试动态sql查询
CREATE TABLE #BookGenreMapping
(
Id int,
BookId int,
Genre varchar(20)
)
INSERT INTO #BookGenreMapping VALUES (1,12,'AB'),(1,05,'AC'),(2,12,'AB'),(2,08,'BC'),(2,09,'BCD')
DECLARE @HeaderAll nvarchar(max)
DECLARE @ColumnPivotBookId nvarchar(max)
DECLARE @ColumnPivotGenre nvarchar(max)
;WITH temp AS
(
SELECT *,
CONCAT('BookID' ,row_number() OVER(PARTITION BY bgm.Id ORDER BY bgm.BookId)) AS BookGroupId,
CONCAT('BookGroupGenre' ,row_number() OVER(PARTITION BY bgm.Id ORDER BY bgm.BookId)) AS BookGroupGenre
FROM #BookGenreMapping bgm
),
temp1 AS
(
SELECT DISTINCT t.BookGroupId, t.BookGroupGenre FROM temp t
)
SELECT @HeaderAll = STUFF((SELECT CONCAT(',',t.BookGroupId, ',', t.BookGroupGenre) FROM temp1 t FOR XML PATH('')), 1,1,''),
@ColumnPivotBookId = STUFF((SELECT CONCAT(',',t.BookGroupId) FROM temp1 t FOR XML PATH('')), 1,1,''),
@ColumnPivotGenre = STUFF((SELECT CONCAT(',', t.BookGroupGenre) FROM temp1 t FOR XML PATH('')), 1,1,'')
--SELECT @HeaderAll, @ColumnPivotBookId, @ColumnPivotGenre
DECLARE @query nvarchar(max) = CONCAT(
';WITH temp AS
(
SELECT *,
CONCAT(''','BookID',''' ,row_number() OVER(PARTITION BY bgm.Id ORDER BY bgm.BookId)) AS BookGroupId,
CONCAT(''','BookGroupGenre',''' ,row_number() OVER(PARTITION BY bgm.Id ORDER BY bgm.BookId)) AS BookGroupGenre
FROM #BookGenreMapping bgm
)
SELECT pt1.Id, ',@HeaderAll,' FROM
(
SELECT Id, ',@ColumnPivotBookId,' FROM
(
SELECT t.Id, t.BookId, t.BookGroupId FROM temp t
) src
PIVOT
(
MIN(BookId) FOR BookGroupId IN (',@ColumnPivotBookId,')
) pvt
) pt1
INNER JOIN
(
SELECT Id, ',@ColumnPivotGenre,' FROM
(
SELECT t.Id, t.Genre, t.BookGroupGenre FROM temp t
) src
PIVOT
(
MIN(Genre) FOR BookGroupGenre IN (',@ColumnPivotGenre,')
) pvt
) pt2 ON pt1.Id = pt2.Id'
)
PRINT @query
exec(@query)
DROP TABLE #BookGenreMapping
问题内容: 我正在尝试不同的JOIN查询,但没有得到想要的结果。 我有2张桌子: 我找不到想要的结果。 我想得到以下结果: 问题答案: 您不能具有这样的动态列数,但是可以 将数据连接 成字符串: 或者您可以使用或手动 旋转行( 我更喜欢后一种方法,对我来说似乎更灵活,但是在某些情况下可以大大减少代码量): 您还可以将前面的语句转换为 动态SQL, 如下所示:
问题内容: 假设我在MySQL数据库中有两个表。 表格1: 表2: 从数据库中选择行时,是否有任何方法可以将第二个表中的行作为列连接到第一个表中? 直接从MySQL查询获得的期望结果是: 谢谢你的帮助! 问题答案: 这种数据转换类型称为PIVOT。MySQL没有枢轴函数,但是您可以使用带有表达式的聚合函数来复制它: 请参阅带有演示的SQL Fiddle。 这也可以使用您的多个联接来编写,并且您将在
问题内容: 我们有些SQL杂语。说我有一个看起来像这样的结果… 61E77D90-D53D-4E2E-A09E-9D6F012EB59C | A 61E77D90-D53D-4E2E-A09E-9D6F012EB59C | B 61E77D90-D53D-4E2E-A09E-9D6F012EB59C | C 61E77D90-D53D-4E2E-A09E-9D6F012EB59C | D 7ce9
在Python中,我有一个像下面这样的长线: 然后我试着把它改成下面的格式。然而,它不再像预期的那样工作了: 我知道Python使用缩进的语法,所以可能这种格式不会工作也许?或者如果有的话,有正确的方法在Python中格式化它吗?
问题内容: 这个问题已经在这里有了答案 : 8年前关闭。 可能重复: 连接行值T-SQL 我是SQL Server的新手,曾经尝试过一些互联网上建议的技术,例如使用临时变量,XML路径等,但是所有这些都不满足我的要求。 我正在使用Toad for SQL Server 5.5版创建SQL脚本,而我用来查询数据库服务器的帐户仅具有READ访问权限。因此不能使用我相信的声明。 表名: 预期产量: 问题
问题内容: 我正在使用SQL Server2008。我具有下表中的数据: 我想以这种格式获取数据: 我怎样才能做到这一点? 问题答案: 使用PIVOT您可以执行以下操作 产生 查看有效的Data.SE示例 在不支持PIVOT的数据库中,您可以改为对表进行多次联接。尽管您可能还是想这样做,但是正如GBN所指出的那样,因为我们没有使用聚合。 查看有效的Data.SE示例