>  기사  >  데이터 베이스  >  알려진 버그가 발생할 때 PDO를 사용하여 출력 매개변수로 저장 프로시저를 호출하는 방법은 무엇입니까?

알려진 버그가 발생할 때 PDO를 사용하여 출력 매개변수로 저장 프로시저를 호출하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-07 15:53:03733검색

How to Call Stored Procedures with Output Parameters Using PDO When Encountering a Known Bug?

PDO를 사용하여 출력 매개변수가 있는 저장 프로시저 호출

PDO를 사용하여 출력 매개변수가 있는 저장 프로시저를 실행하려고 할 때 고려해야 할 사항은 다음과 같습니다. 알려진 버그. 이 버그는 MySQL에서 직접 호출할 때 프로시저가 예상대로 작동함에도 불구하고 다음 오류로 이어질 수 있습니다.

"SQLSTATE[42000]: 구문 오류 또는 액세스 위반: 1414 OUT 또는 INOUT 인수 1 for 루틴 mydb.proc_OUT BEFORE 트리거의 변수 또는 NEW 의사 변수가 아닙니다."

이 문제를 해결하려면 다음을 사용하여 저장 프로시저를 실행하는 것이 좋습니다. 접근 방식:

  1. 저장 프로시저 호출 및 출력 매개변수 선택:
$dbh->query("CALL SomeStoredProcedure($someInParameter1, $someInParameter2, @someOutParameter)");
$dbh->query("SELECT @someOutParameter");
  1. 문 준비 및 출력 선택 매개변수:
$stmt = $dbh->prepare("CALL SomeStoredProcedure(?, ?)");
$stmt->execute(array($someInParameter1, $someInParameter2));

이 접근 방식을 따르면 앞서 언급한 버그가 있는 경우에도 PDO를 사용하여 출력 매개변수가 있는 저장 프로시저를 효과적으로 호출할 수 있습니다.

위 내용은 알려진 버그가 발생할 때 PDO를 사용하여 출력 매개변수로 저장 프로시저를 호출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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