>데이터 베이스 >MySQL 튜토리얼 >Python을 사용하여 MySQL 저장 프로시저에서 결과를 검색하려면 어떻게 해야 합니까?

Python을 사용하여 MySQL 저장 프로시저에서 결과를 검색하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-02 01:59:10763검색

How Can I Retrieve Results from MySQL Stored Procedures Using Python?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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