Как передать список разделенных запятой значений хранимой процедуре?

19
задан Danny Beckett 14 March 2013 в 04:51
поделиться

8 ответов

Если Вы используете Sybase 12.5, или ранее затем Вы не можете использовать функции. Обходное решение могло бы быть должно заполнить временную таблицу со значениями и считать их оттуда.

4
ответ дан 30 November 2019 в 05:21
поделиться

Передайте список разделенных запятой значений в функцию, которая возвращает значение таблицы. Существует пример SQL MS где-нибудь на StackOverflow, проклятом, если я вижу его в данный момент.

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

Вызов с -

exec getSomething 'John,Tom,Foo,Bar'

я предполагаю, что Sybase должен смочь сделать что-то подобное?

1
ответ дан 30 November 2019 в 05:21
поделиться

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

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))
0
ответ дан 30 November 2019 в 05:21
поделиться

Относительно идеи Kevin передать параметр функции, которая разделяет текст на таблицу, вот моя реализация той функции с нескольких лет назад. Работы обработка.

текст Разделения в Слова в SQL

0
ответ дан 30 November 2019 в 05:21
поделиться

Это - быстрый и грязный метод, который может быть полезным:

select  * 
from    mytbl 
where   "," + ltrim(rtrim(@keylist)) + "," like "%," + ltrim(rtrim(name)) + ",%"
0
ответ дан 30 November 2019 в 05:21
поделиться

Не уверенный, если это находится в ASE, но в SQL Где-нибудь, , функция sa_split_list возвращает таблицу из CSV. Это имеет дополнительные аргументы для передачи другого разделителя (значение по умолчанию является запятой), и maxlength для каждого возвращенного значения.

функция sa_split_list

0
ответ дан 30 November 2019 в 05:21
поделиться

Проблема с вызовами как это: должностное лицо getSomething '"John", "Tom"' то, что это рассматривает '"John", "Tom"' как единственная строка, это будет только соответствовать записи в таблице, которая является '"John", "Tom"'.

, Если Вы не хотели использовать временную таблицу в качестве в ответе Paul, затем Вы могли использовать динамический sql. (Принимает v12 +)

CREATE PROCEDURE getSomething @keyList varchar(4096)
AS
declare @sql varchar(4096)
select @sql = "SELECT * FROM mytbl WHERE name IN (" + @keyList +")"
exec(@sql)

, необходимо будет удостовериться, чтобы объекты в @keylist имели кавычки вокруг них, даже если они - единственные значения.

0
ответ дан 30 November 2019 в 05:21
поделиться

Это работает в SQL. Объявите в Вашем GetSomething процедура переменная типа XML как таковой:

DECLARE @NameArray XML = NULL

тело хранимой процедуры реализует следующее:

SELECT * FROM MyTbl WHERE name IN (SELECT ParamValues.ID.value('.','VARCHAR(10)')
FROM @NameArray.nodes('id') AS ParamValues(ID))

Из кода SQL, который называет SP, чтобы объявить и инициализировать переменную XML прежде, чем назвать хранимую процедуру:

DECLARE @NameArray XML

SET @NameArray = '<id><</id>id>Name_1<<id>/id></id><id><</id>id>Name_2<<id>/id></id><id><</id>id>Name_3<<id>/id></id><id><</id>id>Name_4<<id>/id></id>'

Используя Ваш пример вызов к хранимой процедуре был бы:

EXEC GetSomething @NameArray

я использовал этот метод прежде, и он хорошо работает. Если Вы хотите быстрый тест, копируете и вставляете следующий код к новому запросу и выполняетесь:

DECLARE @IdArray XML

SET @IdArray = '<id><</id>id>Name_1<<id>/id></id><id><</id>id>Name_2<<id>/id></id><id><</id>id>Name_3<<id>/id></id><id><</id>id>Name_4<<id>/id></id>'

SELECT ParamValues.ID.value('.','VARCHAR(10)')
FROM @IdArray.nodes('id') AS ParamValues(ID)
0
ответ дан 30 November 2019 в 05:21
поделиться
Другие вопросы по тегам:

Похожие вопросы: