bindParam에서 "참조로 매개변수를 전달할 수 없음" 오류 방지
PDO로 작업할 때 "참조로 매개변수를 전달할 수 없음" 오류가 발생할 수 있습니다. 참조에 의한 매개변수' PDO::PARAM_NULL.
이 오류의 원인은 바인딩 매개변수의 특성에 있습니다. 호출 시 매개변수에 값을 바인딩하는 바인딩값(bindValue)과 달리, 바인드파람(bindParam)은 변수를 참조로 바인딩합니다. 이는 BindParam이 쿼리 실행 중에 수정될 수 있는 변수를 예상한다는 것을 의미합니다. 수정할 수 없는 PDO::PARAM_NULL과 같은 상수 값을 사용하면 오류가 발생합니다.
이 문제를 해결하려면 상수 값에 대해 BindParam 대신 BindValue를 사용하는 것이 해결책입니다. BindValue는 두 번째 매개변수로 값을 허용하며 참조가 필요하지 않습니다.
다음은 BindValue를 올바르게 사용하는 예입니다.
$stmt = $dbh->prepare('INSERT INTO table(v1, v2, ...) VALUES(:v1, :v2, ...)'); $stmt->bindValue(':v1', null, PDO::PARAM_INT);
이 경우, BindValue는 :v1에 null 값을 할당합니다. 데이터 유형이 PDO::PARAM_INT인 매개변수.
PHP 문서에서는 바인딩값(':param', null, PDO::PARAM_NULL), 모든 경우에 작동하지 않을 수 있습니다. 따라서 대신 PDO::PARAM_INT 또는 적절한 데이터 유형을 사용하는 것이 좋습니다.
위 내용은 PDO에서 '참조로 매개변수를 전달할 수 없습니다' 오류가 발생하는 이유는 무엇이며, 바인딩값을 사용하여 이 문제를 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!