Как передать список через запятую хранимой процедуре? - PullRequest
17 голосов
/ 09 августа 2008

Итак, у меня есть сохраненный процесс Sybase, который принимает 1 параметр, который представляет собой список строк, разделенных запятыми, и выполняет запрос с параметром in в условии IN ():

CREATE PROCEDURE getSomething @keyList varchar(4096)
AS
SELECT * FROM mytbl WHERE name IN (@keyList)

Как мне вызвать мой сохраненный процесс с более чем 1 значением в списке? Пока я пробовал

exec getSomething 'John'         -- works but only 1 value
exec getSomething 'John','Tom'   -- doesn't work - expects two variables
exec getSomething "'John','Tom'" -- doesn't work - doesn't find anything
exec getSomething '"John","Tom"' -- doesn't work - doesn't find anything
exec getSomething '\'John\',\'Tom\'' -- doesn't work - syntax error

РЕДАКТИРОВАТЬ: На самом деле я нашел эту страницу , в которой есть множество ссылок на различные способы передачи массива в sproc

Ответы [ 11 ]

0 голосов
/ 09 августа 2008

Вам нужно использовать список через запятую? Последние пару лет я принимал идеи такого типа и передавал XML-файл. «Функция» openxml берет строку и делает ее похожей на xml, а затем, если вы создаете временную таблицу с данными, она запрашивается.

DECLARE @idoc int
DECLARE @doc varchar(1000)
SET @doc ='
<ROOT>
<Customer CustomerID="VINET" ContactName="Paul Henriot">
   <Order CustomerID="VINET" EmployeeID="5" OrderDate="1996-07-04T00:00:00">
      <OrderDetail OrderID="10248" ProductID="11" Quantity="12"/>
      <OrderDetail OrderID="10248" ProductID="42" Quantity="10"/>
   </Order>
</Customer>
<Customer CustomerID="LILAS" ContactName="Carlos Gonzlez">
   <Order CustomerID="LILAS" EmployeeID="3" OrderDate="1996-08-16T00:00:00">
      <OrderDetail OrderID="10283" ProductID="72" Quantity="3"/>
   </Order>
</Customer>
</ROOT>'
--Create an internal representation of the XML document.
EXEC sp_xml_preparedocument @idoc OUTPUT, @doc
-- Execute a SELECT statement that uses the OPENXML rowset provider.
SELECT    *
FROM       OPENXML (@idoc, '/ROOT/Customer',1)
            WITH (CustomerID  varchar(10),
                  ContactName varchar(20))
...