WHERE IN ステートメントの効果的な使用
WHERE IN ステートメントは、指定された値のセットに基づいてレコードを照合するために不可欠です。ただし、適切に構築するのは難しい場合があります。
次を使用しようとしている場合:
WHERE obj IN (?)
指定された値の数がパラメーターの数と一致しない場合、エラーが発生する可能性があります。 。これを解決するには:
statement = "SELECT * FROM tab WHERE obj IN ({0})".format(', '.join(['?'] * len(list_of_vars))) c.execute(statement, list_of_vars)
このアプローチでは、'.join()' と '.format()' を使用して正しい数のパラメーター プレースホルダーを持つステートメントを動的に生成します。
あるいは、大規模な変数リストを使用するより効率的なアプローチとして、一時テーブルの使用を検討してください。 IN 句をバインドパラメータとともに使用する代わりに、一時テーブルをメインテーブルに結合します。この最適化により、必要なデータベース バインドの数が減り、パフォーマンスが向上します。
以上が複数の値を含む WHERE IN ステートメントを効果的に使用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。