Python 커서를 사용하여 저장 프로시저에서 결과 검색
Python에서는 mysql 데이터베이스에 연결하고 저장 프로시저를 실행할 수 있습니다. .connector 모듈. 그러나 저장 프로시저에서 결과를 검색하는 데 문제가 있을 수 있습니다.
이 문제를 해결하려면 저장 프로시저를 호출하는 데 사용되는 커서에 저장된_results() 메서드를 사용하여 결과를 검색하도록 명시적으로 지시해야 합니다. 이 메서드는 결과 집합의 반복자를 반환하므로 저장 프로시저가 여러 결과 집합을 반환하는 경우 여러 결과 집합을 검색할 수 있습니다.
제공된 예에서 저장 프로시저 getperson은 단일 결과 집합을 반환합니다. 다음 코드는 결과를 검색하는 방법을 보여줍니다.
import mysql.connector cnx = mysql.connector.connect(user='root', host='127.0.0.1', database='mytestdb') cnx._open_connection() cursor = cnx.cursor() cursor.callproc("getperson", [1]) for result in cursor.stored_results(): people = result.fetchall() for person in people: print(person) cnx.close()
이 코드에서는 매개변수 1을 사용하여 저장 프로시저를 호출하고 저장된_results() 메서드를 사용하여 단일 결과 집합을 검색합니다. 그런 다음 결과를 반복하여 인쇄합니다.
이 솔루션은 제공된 코드에서 "가져올 결과 세트 없음" 오류 및 여러 결과 세트의 부적절한 처리 등 제공된 코드에서 발생하는 문제를 극복합니다. Stored_results()를 사용하여 결과 집합을 명시적으로 검색하면 코드가 예상대로 저장 프로시저 호출 결과에 액세스할 수 있습니다.
위 내용은 Python을 사용하여 MySQL 저장 프로시저에서 결과를 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!