2016-12-02 91 views
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) 

回答

0

没有办法用骨料运营image数据类型,所以你不能使用PIVOT这里

+0

有没有办法做到这一点,而无需使用一个支点? – Ellinor

+0

这取决于。如果任务只是一次迁移数据的操作,那么我试图创建一个新表,然后逐行填充它的游标 –