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 중국어 웹사이트의 기타 관련 기사를 참조하세요!