집 >데이터 베이스 >MySQL 튜토리얼 >PDO 준비 문에서 동일한 매개변수를 여러 번 효율적으로 사용하려면 어떻게 해야 합니까?
PDO 준비된 명령문에서 매개변수 재사용: 깔끔한 솔루션
PDO에서 준비된 문은 일반적으로 동일한 이름의 매개변수의 재사용을 제한합니다. 이러한 제한으로 인해 동일한 매개변수를 사용하여 여러 일치 기준으로 쿼리를 구성할 때 문제가 발생합니다. 매개변수 이름(:term1, :term2 등)을 수동으로 바꾸는 것은 번거롭고 오류가 발생하기 쉽습니다.
MySQL 사용자 정의 변수 활용
더 효율적이고 읽기 쉬운 접근 방식에는 MySQL의 사용자 정의 변수가 포함됩니다. 이 방법은 매개변수 관리를 간소화하고 코드 유지 관리성을 향상시킵니다.
이 과정에는 다음 단계가 포함됩니다.
변수 초기화: PDOStatement::bindParam
를 사용하여 사용자 정의 변수에 값을 할당합니다.
<code class="language-php"> $stmt = $dbh->prepare("SET @term = :term"); $stmt->bindParam(":term", "%$term%", PDO::PARAM_STR);</code>
쿼리 통합: SQL 쿼리에서 원래 매개변수의 여러 인스턴스를 사용자 정의 변수(@term
)로 대체합니다.
<code class="language-sql"> SELECT ... FROM table WHERE name LIKE @term OR number LIKE @term</code>
문 실행: 수정된 쿼리를 준비하고 실행합니다.
<code class="language-php"> $stmt = $dbh->prepare($sql); $stmt->execute();</code>
예시:
이 복잡한 쿼리를 생각해 보세요.
<code class="language-sql">( SELECT t1.`name` AS resultText FROM table1 AS t1 WHERE t1.parent = :userID AND ( t1.`name` LIKE :term OR t1.`number` LIKE :term AND t1.`status` = :flagStatus ) ) UNION ( SELECT t2.`name` AS resultText FROM table2 AS t2 WHERE t2.parent = :userParentID AND ( t2.`name` LIKE :term OR t2.`ticket` LIKE :term AND t1.`state` = :flagTicket ) )</code>
사용자 정의 변수를 사용한 리팩토링 결과:
<code class="language-sql">SET @term = :term; ( SELECT t1.`name` AS resultText FROM table1 AS t1 WHERE t1.parent = :userID AND ( t1.`name` LIKE @term OR t1.`number` LIKE @term AND t1.`status` = :flagStatus ) ) UNION ( SELECT t2.`name` AS resultText FROM table2 AS t2 WHERE t2.parent = :userParentID AND ( t2.`name` LIKE @term OR t2.`ticket` LIKE @term AND t1.`state` = :flagTicket ) )</code>
이 접근 방식의 장점:
위 내용은 PDO 준비 문에서 동일한 매개변수를 여러 번 효율적으로 사용하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!