ホームページ > バックエンド開発 > PHPチュートリアル > PDO クエリの IN() 句に配列をバインドするにはどうすればよいですか?

PDO クエリの IN() 句に配列をバインドするにはどうすればよいですか?

Susan Sarandon
リリース: 2024-12-19 20:33:11
オリジナル
136 人が閲覧しました

How Can I Bind an Array to an IN() Clause in a PDO Query?

PDO クエリの IN() 条件に配列値をバインドできますか?

値の配列を IN() にバインドするPDO を使用して条件を設定することは可能ですが、手動でプレースホルダーを構築する必要があります。方法は次のとおりです:

  1. プレースホルダーの作成: 配列要素の数に対応するプレースホルダーの文字列を構築します。たとえば、配列に 3 つの値が含まれている場合、プレースホルダー文字列は「?,?」になります。
  2. Prepare Statement: 構築されたプレースホルダーで IN() 条件を使用して PDO ステートメントを準備します。 .
  3. ステートメントの実行: 準備されたステートメントを実行し、配列の値を引数として渡します。 PDO は値を自動的にバインドして引用符で囲みます。

例を示します:

$ids = [1, 2, 3, 7, 8, 9];
$inQuery = str_repeat('?,', count($ids) - 1) . '?'; // ?,?,?,?,?,?

$stmt = $db->prepare("SELECT * FROM table WHERE id IN($inQuery)");
$stmt->execute($ids);
ログイン後にコピー

名前付きプレースホルダーの場合:

  1. 作成Placeholder Sequence: 配列要素に対応する名前付きプレースホルダーのシーケンスを作成します。 :id0,:id1,:id2.
  2. 値の収集: プレースホルダー シーケンスをキーとして使用して、配列値をキーと値の配列に収集します。
  3. 準備と実行: ステートメントを準備して実行し、パラメーターをマージしますarrays.

例を示します:

$ids = [1, 2, 3];
$in = "";
$i = 0; // external counter
foreach ($ids as $item) {
    $key = ":id" . $i++;
    $in .= ($in ? "," : "") . $key; // :id0,:id1,:id2
    $in_params[$key] = $item; // collect values
}

$sql = "SELECT * FROM table WHERE id IN ($in)";
$stmt = $db->prepare($sql);
$stmt->execute(array_merge(["foo" => "foo", "bar" => "bar"], $in_params));
ログイン後にコピー

以上がPDO クエリの IN() 句に配列をバインドするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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