SQL Server (2008) Передайте ArrayList или String в SP для IN () - PullRequest
2 голосов
/ 06 февраля 2009

Мне было интересно, как я могу передать список разделенных запятыми ArrayList, List <int> или StringBuilder в хранимую процедуру, чтобы найти список идентификаторов с помощью IN ():

@myList varchar(50)

SELECT  *
FROM    tbl
WHERE   Id IN (@myList)

В C # я сейчас строю список в виде строки, разделенной запятой; однако при использовании nvarchar (50), например, в качестве типа параметра в хранимой процедуре - я получаю сообщение об ошибке, поскольку он не может преобразовать '1,2,3' в int, которое он ожидает между IN ().

Есть идеи? Очень признателен.
Пит

Ответы [ 2 ]

2 голосов
/ 06 февраля 2009

В SQL 2008 есть табличные параметры, которые являются дружественной альтернативой синтаксическому анализу CSV; см. здесь пример .

В противном случае, другой вариант - xml - тип данных xml в SQL Server позволяет вам легко это прочитать (хотя это занимает больше байтов передачи).

2 голосов
/ 06 февраля 2009

Вы можете использовать пользовательскую функцию, такую ​​как

CREATE function [dbo].[csl_to_table] ( @list nvarchar(MAX) )
RETURNS @list_table TABLE ([id] INT)
AS
BEGIN
    DECLARE     @index INT,
            @start_index INT,
            @id INT

    SELECT @index = 1 
    SELECT @start_index = 1
    WHILE @index <= DATALENGTH(@list)
    BEGIN

        IF SUBSTRING(@list,@index,1) = ','
        BEGIN

            SELECT @id = CAST(SUBSTRING(@list, @start_index, @index - @start_index ) AS INT)
            INSERT @list_table ([id]) VALUES (@id)
            SELECT @start_index = @index + 1
        END
        SELECT @index  = @index + 1
    END
    SELECT @id = CAST(SUBSTRING(@list, @start_index, @index - @start_index ) AS INT)
    INSERT @list_table ([id]) VALUES (@id)
    RETURN
END

Который принимает список идентификаторов, разделенных запятыми, и возвращает таблицу этих идентификаторов в виде целых чисел. Затем вы можете присоединиться к возвращенной таблице в вашей хранимой процедуре следующим образом -

DECLARE @passed_in_ids TABLE (id INT)

INSERT INTO @passed_in_ids (id)
  SELECT 
    id 
  FROM
    [dbo].[csl_to_table] (@your_passed_in_csl)

SELECT *
FROM 
myTable
INNER JOIN
@passed_in_ids ids
ON
myTable.id = ids.id
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...