19

したがって、文字列のコンマ区切りリストである 1 つのパラメーターを取り、IN() 句でクエリを実行する Sybase ストアド プロシージャがあります。

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

リストに複数の値があるストアド プロシージャを呼び出すにはどうすればよいですか? これまで私は試しました

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に渡すさまざまな方法の優れたリファレンスがあるこのページを見つけました

4

11 に答える 11

4

Sybase 12.5 以前を使用している場合は、関数を使用できません。回避策として、一時テーブルに値を入力し、そこから読み取ることができます。

于 2008-08-14T09:27:30.793 に答える
2

これは少し遅れていますが、私はこの正確な問題を少し前に抱えていて、解決策を見つけました.

トリックは、二重引用符で囲み、文字列全体を引用符で囲むことです。

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

テーブル エントリが文字列と一致するように proc を変更します。

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

ASE 12.5 以降、これを運用しています。現在は 15.0.3 です。

于 2011-10-25T16:01:30.880 に答える
1

コンマ区切りのリストを、テーブル値を返す関数に渡します。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'

Sybase も同様のことができるはずだと思いますか?

于 2008-08-08T21:04:58.703 に答える
0

コンマ区切りのリストを使用する必要がありますか? ここ数年、私はこの種のアイデアを取り入れて、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))
于 2008-08-08T20:57:51.150 に答える
0

@Abelが提供したものに触れると、私を助けたのは次のとおりです。

私の目的は、エンド ユーザーが SSRS から入力したものを取得し、それを where 句で In (SELECT) として使用することでした。明らかに、@ICD_VALUE_RPT はデータセット クエリでコメント アウトされます。

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))
)
于 2016-06-03T01:13:32.650 に答える
0

テキストをテーブルに分割する関数にパラメーターを渡すというケビンのアイデアに関して、数年前からその関数を実装しています。御馳走を働きます。

SQL でテキストを単語に分割する

于 2008-08-09T00:05:04.847 に答える
0

これは便利な手っ取り早い方法です。

select  * 
from    mytbl 
where   "," + ltrim(rtrim(@keylist)) + "," like "%," + ltrim(rtrim(name)) + ",%"
于 2008-09-07T13:18:46.057 に答える
0

ASE にあるかどうかはわかりませんが、SQL Anywhere では、sa_split_list関数は CSV からテーブルを返します。異なる区切り文字 (デフォルトはコンマ) を渡すオプションの引数と、返される値ごとに最大長を指定します。

sa_split_list 関数

于 2008-09-23T20:17:38.717 に答える
0

これは 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)
于 2008-10-30T17:57:16.700 に答える
0

次のような呼び出しの問題: exec getSomething '"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 の項目が単一の値であっても、引用符で囲む必要があります。

于 2008-09-23T20:36:39.560 に答える