SQL Server:在动态查询中执行Temp表

时间:2017-03-23 21:45:50

标签: sql-server dynamicquery

我正在使用临时表和动态查询以及。我的要求是在临时表中我插入一些独特的值。从临时表开始,我获得了唯一的密钥,并在条件的内部实现。

这是代码

临时表:

Create Table #TempUniqueKeyTable
(
     ID BIGINT IDENTITY PRIMARY KEY, 
     ukey uniqueidentifier
)

INSERT INTO #TempUniqueKeyTable (ukey) 
    SELECT followedTo 
    FROM tblFollowers 
    WHERE FollowedBy = @uniqueKey

INSERT INTO #TempUniqueKeyTable (ukey) 
    SELECT connectionRequestTo 
    FROM tblConnection 
    WHERE connectRequestBY = @uniqueKey

INSERT INTO #TempUniqueKeyTable (ukey) 
    SELECT connectRequestBY 
    FROM tblConnection 
    WHERE connectionRequestTo = @uniqueKey

动态查询:

SET @QueryHeader = 'SELECT * from XYZ B'
SET @MainQuery = @QueryHeader
SET @MainQuery += ' WHERE B.uniquekey in (SELECT distinct ukey FROM #TempUniqueKeyTable  WHERE ukey='''+CONVERT(NVARCHAR(MAX),@UniqueKey)+''')) '

EXEC (@MainQuery)

状态不佳。这部分没有返回任何值

SELECT distinct ukey 
FROM #TempUniqueKeyTable  
WHERE ukey = ''' + CONVERT(NVARCHAR(MAX), @UniqueKey) + ''')

当我运行PRINT命令时,它显示生成的查询,如

SELECT * 
FROM XYZ B 
WHERE B.uniquekey IN (SELECT DISTINCT ukey 
                      FROM #TempUniqueKeyTable  
                      WHERE ukey = '1EA8658C-F978-4DC7-9ABF-E4FF253A2284')

应该是

SELECT * from XYZ B 
  WHERE B.uniquekey in ('A5B6BC01-5FEB-4554-90A7-4B5ADCC00D36','F75C6303-40EB-4119-A45A-D122E8118FA4')

1 个答案:

答案 0 :(得分:1)

你有一个额外的右括号:

SET @MainQuery+= ' WHERE B.uniquekey in (SELECT distinct ukey FROM #TempUniqueKeyTable WHERE ukey='''+CONVERT(NVARCHAR(MAX),@UniqueKey)+''') '

但我想这是你自己可以很容易识别的东西。也许我不明白这个问题?

修改 您可以使用此方法构建IN子句。当临时表没有数据时,应特别注意确保@MainQuery返回正确的结果(即什么都没有)。

declare @QueryHeader NVarchar(max);
declare @MainQuery NVarchar(max);


SET @QueryHeader='SELECT * from XYZ B'

if exists (select * from #TempUniqueKeyTable)
begin
    SET @MainQuery = @QueryHeader;
    declare @WhereClause nvarchar(max);
    set @WhereClause = ' WHERE B.uniquekey in (';

    declare @curr uniqueidentifier;
    select @curr = min(ukey) from #TempUniqueKeyTable;
    while @curr is not null
    begin
        set @WhereClause = @WhereClause + '''' + cast(@curr as nvarchar(40)) + ''',';
        select @curr = min(ukey) from #TempUniqueKeyTable where ukey > @curr;
    end

    set @WhereClause = left(@WhereClause, len(@WhereClause) - 1) + ')';

    set @MainQuery = @QueryHeader + @WhereClause;
end
else
-- make sure nothing is returned, for example:
begin
    set @MainQuery = @QueryHeader + ' WHERE 1 = 0'; 
end

EXEC (@MainQuery);