PDO를 사용하여 출력 매개변수가 있는 저장 프로시저 호출
PDO를 사용하여 출력 매개변수가 있는 저장 프로시저를 실행하려고 할 때 고려해야 할 사항은 다음과 같습니다. 알려진 버그. 이 버그는 MySQL에서 직접 호출할 때 프로시저가 예상대로 작동함에도 불구하고 다음 오류로 이어질 수 있습니다.
"SQLSTATE[42000]: 구문 오류 또는 액세스 위반: 1414 OUT 또는 INOUT 인수 1 for 루틴 mydb.proc_OUT BEFORE 트리거의 변수 또는 NEW 의사 변수가 아닙니다."
이 문제를 해결하려면 다음을 사용하여 저장 프로시저를 실행하는 것이 좋습니다. 접근 방식:
$dbh->query("CALL SomeStoredProcedure($someInParameter1, $someInParameter2, @someOutParameter)"); $dbh->query("SELECT @someOutParameter");
$stmt = $dbh->prepare("CALL SomeStoredProcedure(?, ?)"); $stmt->execute(array($someInParameter1, $someInParameter2));
이 접근 방식을 따르면 앞서 언급한 버그가 있는 경우에도 PDO를 사용하여 출력 매개변수가 있는 저장 프로시저를 효과적으로 호출할 수 있습니다.
위 내용은 알려진 버그가 발생할 때 PDO를 사용하여 출력 매개변수로 저장 프로시저를 호출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!