代码之家  ›  专栏  ›  技术社区  ›  naumcho

如何将逗号分隔的列表传递给存储过程?

  •  17
  • naumcho  · 技术社区  · 16 年前

    因此,我有一个Sybase存储过程,它接受1个参数,这是一个逗号分隔的字符串列表,并使用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
    

    我真的找到了这个 page 这对将数组复制到存储过程的各种方法有很大的参考价值

    11 回复  |  直到 12 年前
        1
  •  4
  •   gonzobrains Etienne Lawlor    11 年前

    如果您使用的是Sybase 12.5或更早版本,则无法使用函数。一种解决方法可能是用值填充临时表并从中读取它们。

        2
  •  2
  •   Ben    13 年前

    这有点晚了,但我不久前就遇到了这个问题,我找到了一个解决方案。

    exec getSomething """John"",""Tom"",""Bob"",""Harry"""
    

    修改进程以使表条目与字符串匹配。

    CREATE PROCEDURE getSomething @keyList varchar(4096)
    AS
    SELECT * FROM mytbl WHERE @keyList LIKE '%'+name+'%' 
    

    从ASE 12.5开始,我就在生产中使用它;现在是15.0.3。

        3
  •  1
  •   erlando    16 年前

    将逗号分隔的列表传递到返回表值的函数中。在StackOverflow上的某个地方有一个MS SQL示例,如果我现在能看到的话,那真该死。

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

    打电话给-

    exec getSomething 'John,Tom,Foo,Bar'
    

        4
  •  0
  •   Brian Childress    16 年前

    是否需要使用逗号分隔的列表?在过去的几年中,我一直接受这种想法,并传入一个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))
    
        5
  •  0
  •   Matt Hamilton    16 年前

    关于Kevin将参数传递给将文本拆分为表的函数的想法,下面是几年前我对该函数的实现。工作是一种享受。

    Splitting Text into Words in SQL

        6
  •  0
  •   xx xx    16 年前

    这是一种快速而肮脏的方法,可能很有用:

    select  * 
    from    mytbl 
    where   "," + ltrim(rtrim(@keylist)) + "," like "%," + ltrim(rtrim(name)) + ",%"
    
        7
  •  0
  •   Lurker Indeed    16 年前

    不确定它是否在ASE中,但在SQL Anywhere中 函数从CSV返回一个表。它具有可选参数,可以为每个返回值传递不同的分隔符(默认为逗号)和maxlength。

    sa_split_list function

        8
  •  0
  •   AdamH    16 年前

    类似这样的调用的问题是:exec 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中的项周围有引号,即使它们是单值。

        9
  •  0
  •   DeFlanko    8 年前

    我的目的是获取最终用户从SSRS输入的内容,并在我的where子句中将其用作in(SELECT)

    DECLARE @ICD_VALUE_RPT VARCHAR(MAX) SET @ICD_VALUE_RPT = 'Value1, Value2'
    DECLARE @ICD_VALUE_ARRAY XML SET @ICD_VALUE_ARRAY = CONCAT('<id>', REPLACE(REPLACE(@ICD_VALUE_RPT, ',', '</id>,<id>'),' ',''), '</id>')
    

    然后在我的 WHERE 我补充说:

    (PATS_WITH_PL_DIAGS.ICD10_CODE IN (SELECT ParamValues.ID.value('.','VARCHAR(MAX)') FROM @ICD_VALUE_ARRAY.nodes('id') AS ParamValues(ID))
    OR PATS_WITH_PL_DIAGS.ICD9_CODE IN (SELECT ParamValues.ID.value('.','VARCHAR(MAX)') FROM @ICD_VALUE_ARRAY.nodes('id') AS ParamValues(ID))
    )
    
        10
  •  0
  •   user3732708    7 年前

    @itemIds varchar(max)
    
    CREATE PROCEDURE getSomething @keyList varchar(4096)
    AS
    SELECT * FROM mytbl WHERE name IN (SELECT Value FROM [Global_Split] (@itemIds,','))
    
        11
  •  0
  •   MarredCheese Lionia Vasilev    5 年前

    这在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))
    

    从调用SP以在调用存储过程之前声明和初始化XML变量的SQL代码中:

    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)
    
    推荐文章