MySQL 오류 2014의 원인: 버퍼링되지 않은 다른 쿼리가 활성화되어 있는 동안 쿼리를 실행할 수 없습니다
이 오류는 이전에 새 쿼리를 실행하려고 할 때 발생합니다. 버퍼링되지 않은 이전 쿼리의 결과 처리를 완료합니다. MySQL의 클라이언트 프로토콜은 여러 쿼리가 동시에 "진행 중"인 것을 허용하지 않습니다.
해결책:
-
PDO::fetchAll() 사용: 이 메서드는 이전 쿼리의 모든 결과를 암시적으로 가져와 다음 쿼리의 실행을 허용합니다. query.
-
쿼리 버퍼링 활성화: PDO::MYSQL_ATTR_USE_BUFFERED_QUERY를 true로 설정하면 클라이언트 라이브러리가 PHP 대신 내부적으로 결과를 버퍼링하게 됩니다.
-
CloseCursors: 완료되었음을 서버에 알리기 위해 closeCursor()를 호출합니다. 쿼리에서 결과 가져오기.
추가 권장 사항:
- 루프 불변 코드를 루프 외부로 이동: 루프 내에서도 동일한 결과가 나옵니다.
- 매개변수를 단순화하려면 준비된 명령문에 명명된 매개변수를 사용하세요. 통과.
- 향상된 기능과 효율성을 위해 mysqlnd 클라이언트 라이브러리 사용을 고려해 보세요.
위 내용은 MySQL 오류 2014: '버퍼링되지 않은 다른 쿼리가 활성 상태인 동안 쿼리를 실행할 수 없습니다'가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!