Python MySQL: 저장 프로시저 실행 시 "명령이 동기화되지 않음" 오류 해결
Python 프로그래밍에서 Django를 활용하여 저장 프로시저를 실행할 때 MySQL 데이터베이스 내에서 일부 사용자에게 "명령이 동기화되지 않았습니다. 지금은 이 명령을 실행할 수 없습니다" 오류가 발생합니다.
이 오류는 일반적으로 커밋 작업을 수행하지 않고 프로시저 호출 이후 비select 문(예: 업데이트 또는 삭제 작업)을 실행하려고 할 때 발생합니다.
다음 코드 예제를 고려하십시오.
cursor.callproc('my_mysql_procedure', [some_id,]) result = cursor.fetchall() for r in result: do something cursor.execute("select * from some_table") result = cursor.fetchall()
저장 프로시저를 실행한 후 비선택 작업을 시도하면 연결이 "동기화되지 않음"이 됩니다. 먼저 커서를 닫았다가 다시 열지 않고.
이 문제를 해결하려면 저장 프로시저에서 결과를 검색한 후 즉시 커서를 닫는 것이 좋습니다.
cursor.close() cursor = connection.cursor()
새 커서는 연결이 재설정되고 올바르게 동기화되도록 보장하여 후속 명령문이 의도한 대로 실행되도록 합니다. 프로시저 호출에서 얻은 결과 세트는 커서를 닫은 후에도 계속 액세스할 수 있다는 점에 유의하는 것이 중요합니다.
위 내용은 Python 및 MySQL 저장 프로시저를 사용할 때 \'명령이 동기화되지 않음\' 오류를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!