ホームページ > バックエンド開発 > PHPチュートリアル > MySQL のプリペアドステートメントで動的にサイズ変更されたパラメータリストを処理するにはどうすればよいですか?

MySQL のプリペアドステートメントで動的にサイズ変更されたパラメータリストを処理するにはどうすればよいですか?

DDD
リリース: 2024-12-03 03:14:09
オリジナル
484 人が閲覧しました

How to Handle Dynamically Sized Parameter Lists in MySQL Prepared Statements?

MySQL プリペアド ステートメントの動的サイズのパラメータ リスト

PHP で MySQL プリペアド ステートメントを構築する場合、可変数の引数を持つクエリをどのように処理するかという問題が生じます。たとえば、次のようなクエリを考えてみましょう。

SELECT `age`, `name` FROM `people` WHERE id IN (12, 45, 65, 33)
ログイン後にコピー

IN 句の ID の数は実行ごとに変化します。

考えられる解決策

対処するにはさまざまなアプローチが存在します。このチャレンジ:

  1. 解決策 1: ダミー変数と複数の呼び出し

    • 固定数の変数 (例: 100) を受け入れるステートメントを作成し、未使用のスロットをダミー値で埋めます。
    • より大きな変数については複数の呼び出しを実行します。 set.
  2. 解決策 2: 準備されていないクエリ

    • クエリを動的に構築して実行し、厳格な保護を確保します。注射に対して

最適な解決策

ただし、他のオプションの方がより効率的です:

  1. 一時テーブルアプローチ

    • 作成一時テーブルを作成し、そこに各パラメータ値を挿入します。
    • 一時テーブルに対して単純な結合を実行します。
  2. Dynamic IN 句

    • 次を使用して、IN 句のプレースホルダーを使用してクエリを動的に構築します。 implode 関数と配列プレフィル関数。
    • 例:

      $dbh = new PDO(...);
      $parms = [12, 45, 65, 33];
      $inclause = implode(',', array_fill(0, count($parms), '?')); // = ?,?,?,?
      $preparesql = sprintf('SELECT age, name FROM people WHERE id IN (%s)', $inclause);
      $st = $dbh->prepare($preparesql);
      $st->execute($parms);
      ログイン後にコピー

大規模なセットの場合は、最初のアプローチの方が効率的である可能性があります。一方、2 番目は小さいものに適しています。

以上がMySQL のプリペアドステートメントで動的にサイズ変更されたパラメータリストを処理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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