>백엔드 개발 >PHP 튜토리얼 >PDO에서 \'참조로 매개변수를 전달할 수 없습니다\' 오류가 발생하는 이유는 무엇이며, 바인딩값을 사용하여 이 문제를 어떻게 해결할 수 있습니까?

PDO에서 \'참조로 매개변수를 전달할 수 없습니다\' 오류가 발생하는 이유는 무엇이며, 바인딩값을 사용하여 이 문제를 어떻게 해결할 수 있습니까?

DDD
DDD원래의
2024-12-23 20:29:11567검색

Why Does PDO Throw a

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.