ホームページ >バックエンド開発 >PHPチュートリアル >PDO クエリの IN() 句に配列をバインドするにはどうすればよいですか?
PDO クエリの IN() 条件に配列値をバインドできますか?
値の配列を IN() にバインドする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);
名前付きプレースホルダーの場合:
例を示します:
$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 サイトの他の関連記事を参照してください。