ホームページ > データベース > mysql チュートリアル > カンマ区切りの値を SQL Server IN 関数に効率的に渡す方法

カンマ区切りの値を SQL Server IN 関数に効率的に渡す方法

Mary-Kate Olsen
リリース: 2025-01-22 04:25:09
オリジナル
534 人が閲覧しました

How to Efficiently Pass Comma-Delimited Values to a SQL Server IN Function?

区切り文字で区切られた値を SQL Server IN 関数に渡します

カンマ区切りの文字列値を SQL Server の IN 関数に渡すのは難しい場合があります。区切り文字で区切られた文字列を含む IN 関数を直接使用すると、変換エラーが発生します。

オプション 1: 動的 SQL

1 つの方法は動的 SQL を使用することです。これにより、IN 句を動的に構築できます。ただし、セキュリティとパフォーマンスの問題のため、この方法はお勧めできません。

オプション 2: 文字列操作

より効率的で安全な解決策は、区切り文字で区切られた文字列を IN 関数で受け入れられる形式に操作することです。 1 つのオプションは、CHARINDEX() 関数を使用して、区切り文字で区切られた文字列の各値がテーブル内の列の値と一致するかどうかを確認することです。

<code class="language-sql">DECLARE @Ids varchar(50) = ',1,2,3,5,4,6,7,98,234,'

SELECT * 
FROM sometable
WHERE CHARINDEX(','+CAST(tableid AS VARCHAR(8000))+',', @Ids) > 0</code>
ログイン後にコピー
この方法では動的 SQL が必要ないため、セキュリティとパフォーマンスの利点のバランスが取れています。

簡単な解決策

あまりエレガントではないが、より便利なソリューションを探している人のために、簡単なトリックがあります:

<code class="language-sql">DECLARE @Ids varchar(50) = ',1,2,3,5,4,6,7,98,234,'

SELECT * 
FROM sometable
WHERE ',' + CONVERT(VARCHAR, tableid) + ',' LIKE '%,' + @Ids + '%';</code>
ログイン後にコピー
このメソッドは CHARINDEX() メソッドほど効率的ではありませんが、迅速かつ簡単な代替手段となります。

以上がカンマ区切りの値を SQL Server IN 関数に効率的に渡す方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート