具有多值参数的存储过程表现奇怪

时间:2018-02-28 13:55:22

标签: sql sql-server tsql stored-procedures reporting-services

我在sql server中创建了一个存储过程来提供SSRS以允许它接受多个值。 我已创建它,当我在我的报告中使用它或在sql server中执行它时,我有以下错误消息。有什么我想念的吗?感谢

Socket

这是我的样本数据。随意用它创建表

Msg 207, Level 16, State 1, Line 35
Invalid column name 'London'.

这是我的动态存储过程代码

DECLARE @MyTables AS TABLE (ID INT, City VARCHAR(100))
INSERT INTO @MyTables VALUES
(1,'London'),
(2,'Chester'),
(3,'Luton'),
(4,'New York'),
(1,'London'),
(2,'Chester'),
(5,'Paris'),
(5,'Paris'),
(2,'Chester'),
(2,'Chester')
SELECT * FROM @MyTables

谢谢

CREATE PROCEDURE dbo.CitiesGroup
        @Cities NVARCHAR(Max) -- this are the parameters
    AS
    BEGIN
    DECLARE @sqLQuery VARCHAR(MAX)
    Declare @AnswersTempTable Table
    (  ID  INT,
       City VARCHAR(250)
    )
SET @sqlQuery =
    'SELECT  
    ID,
    City
FROM MyTables
where Convert(nvarchar(Max),City) IN ('+@Cities+')
Insert into @AnswersTempTable
exec (@sqlQuery)
select * from @AnswersTempTable'
END

错误meg

EXEC dbo.CitiesGroup 'London'

2 个答案:

答案 0 :(得分:1)

还有另一种方法可以做到这一点。而不是将值传递给动态查询,为什么不使用函数拆分参数? This article编写的Aaron Bertrand演示了如何在sql server中拆分字符串的不同方法。

选择其中一个功能后,您只需重写存储过程,而无需在其中创建动态查询。

CREATE PROCEDURE dbo.CitiesGroup
    @Cities NVARCHAR(Max) -- this are the parameters
AS
BEGIN
    -- simplified query
    -- write your complex logic here
    SELECT ID, City
    FROM MyTables
    WHERE City IN (SELECT Item FROM dbo.SplitStrings_CTE(@Cities, N',');)
END

用法:

EXEC dbo.CitiesGroup 'London'
GO

EXEC dbo.CitiesGroup 'London,New York,Paris'
GO

有用的链接:

Split strings the right way – or the next best way

答案 1 :(得分:0)

或者,如果您不需要使用存储过程,则只需将查询直接放在数据集中

SELECT ID, City
   FROM MyTables
   WHERE City IN (@Cities)

不需要动态sql,因为SSRS会为您执行此操作。只需确保SELECT语句中的SSRS参数名称和变量相同(区分大小写)