2015-12-03 72 views
0

我有两个表。 表1:Question_Master其中包含的问题动态决定连接数

id question 
    1 Q1 
    2 Q2 
    3 Q3 

表2:选择主站,它包含的选项

id option 
1 H 
2 N 
3 S 

我想要的选项所有组合的所有问题。

像这样

Q1 Q2 Q3 
    H H H 
    H H N 
    H H s 
    H N H 

注:可以有任意数量的中均有记载table.If它有4个记录option_master比我想的4条记录所有组合。

+2

交叉连接+旋转表!查看它! –

+0

你已经尝试过了,但问题是,如何动态决定交叉连接的数量。基于question_master中的记录数 – gkarya42

+0

寻找'动态数据转换表sql服务器'你会发现很多答案! –

回答

1

您可以通过使用一些字符串连接查询基础上,Question_Master表打造出来的Select语句做动态值

DECLARE @SelectSQL VARCHAR(MAX), 
     @JoinSQL VARCHAR(MAX), 
     @OrderSQL VARCHAR(MAX) 

SELECT @SelectSQL = COALESCE(@SelectSQL + ',', '') 
      + QUOTENAME(question) + '.[option] as ' + QUOTENAME(question), 
     @JoinSQL = COALESCE(@JoinSQL + ' CROSS JOIN ', '') 
      + 'Option_Master as ' + QUOTENAME(question), 
     @OrderSQL = COALESCE(@OrderSql + ',', '') 
      + QUOTENAME(question) + '.[option]' 
FROM Question_Master 
ORDER BY question 


DECLARE @Sql AS NVARCHAR(MAX) = N'SELECT ' + @SelectSQL + ' FROM ' + @JoinSQL + ' ORDER BY ' + @OrderSQL 
EXECUTE sp_executesql @Sql; 

使用QUOTENAME将允许您有问题的值有空格或其他字符。

SQL Fiddle Example

+0

您是天才。有时我们使事情变得复杂。我试图解决使用枢轴,谢谢 – gkarya42

1

您需要CROSS加入Option_Master自己。然后您需要再次与Option_Master交叉加入结果。这个问题必须重复。我认为这必须通过动态创建SQL语句来完成。尝试这个例子来得到一个想法:

declare @NumberOfQuestions int 

set @NumberOfQuestions = (
    select count(*) 
    from question_master 
    ) 

declare @sql varchar(max) 

set @sql = 'select om1.opt ' 

declare @counter int 

set @counter = 2 
while @Counter <= @NumberOfQuestions 
begin 
    set @sql = @sql + ' 
    , om' + cast (@counter as varchar(1)) + '.opt ' 
    set @counter = @counter + 1 
end 

set @sql = @sql + ' 
    from option_master om1 ' 

set @counter = 2 
while @Counter <= @NumberOfQuestions 
begin 
    set @sql = @sql + ' 
    cross join option_master om' + cast(@counter as varchar(1)) + ' ' 
    set @counter = @counter + 1 
end 

set @sql = @sql + ' 
    order by om1.opt ' 

set @counter = 2 
while @Counter <= @NumberOfQuestions 
begin 
    set @sql = @sql + ' 
    , om' + cast(@counter as varchar(1)) + '.opt ' 
    set @counter = @counter + 1 
end 

exec (@sql) 

阿尔伯特

+0

将exec(@Sql)更改为print(@sql)以查看生成的SQL –