0
我想实现一个动态的数据透视表,其中两个表连接在一起,一组图像成为他们自己的列。动态sql枢纽加入
表1:
house_id name value
1 image image1.jpg
1 image image2.jpg
1 image image3.jpg
表2:
id updated_at house_name
1 2016-12-02 House 1
我希望它看起来像这样:
house_id updated_at house_name image1 image2 image3
1 2016-12-02 House 1 image1.jpg image2.jpg image3.jpg
我想通过一个动态的SQL支点来实现这一点,但我无法让它工作(即使没有加入):
DECLARE @cols AS NVARCHAR(MAX)='';
DECLARE @query AS NVARCHAR(MAX)='';
SELECT @cols = @cols + QUOTENAME(name) + ',' FROM (select distinct name from #table1) as house_meta
select @cols = substring(@cols, 0, len(@cols)) --trim "," at end
set @query =
'SELECT * from
(
select house_id, name, value from #table1
) src
pivot
(
max(value) for name in (' + @cols + ')
) piv'
execute(@query)
有没有办法做到这一点,而无需使用一个支点? – Ellinor
这取决于。如果任务只是一次迁移数据的操作,那么我试图创建一个新表,然后逐行填充它的游标 –