ホームページ >データベース >mysql チュートリアル >`fetchone()` を使用すると、Python MySQL コネクタが「未読の結果が見つかりました」エラーをスローするのはなぜですか?

`fetchone()` を使用すると、Python MySQL コネクタが「未読の結果が見つかりました」エラーをスローするのはなぜですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-11-29 19:30:16187ブラウズ

Why Does My Python MySQL Connector Throw an

Python MySQL コネクタ: Fetchone 使用時に「未読の結果が見つかりました」

Python コネクタを使用して解析された JSON データを MySQL データベースに挿入するとき、 「未読の結果が見つかりました。」というエラーが発生します。このエラーは、コードの特定のセクションに関連付けられています。

コード スニペットでは、cursor.execute メソッドを使用して一連のクエリが実行され、その後、cursor.fetchone を呼び出して、結果セット。ただし、このコードをより大きなプログラムに追加すると、同じカーソルを使用する後続のクエリは「未読の結果が見つかりました」エラーで失敗します。

このエラーは、前のクエリで未処理の結果があることを示しています。この問題を解決するには、cursor.fetchall メソッドを使用して各クエリの結果を抽出することをお勧めします。ただし、mysql.connector.errors.InterfaceError を処理するために Try-Except ブロック内でこれを実行しようとすると、失敗することが判明しました。

エラーの原因となるコードの特定のセクションは次のとおりです:

cursor.execute(query,(travel_mode, Orig_lat, Orig_lng, Dest_lat, Dest_lng, time_stamp))
leg_no = cursor.fetchone()[0]
try:
    cursor.fetchall()
except mysql.connector.errors.InterfaceError as ie:
    if ie.msg == 'No result set to fetch from.':
        pass
    else:
        raise
cursor.execute(query,(leg_travel_mode, leg_Orig_lat, leg_Orig_lng, leg_Dest_lat, leg_Dest_lng, time_stamp))

この問題を解決するには、カーソルの作成時にバッファリングされたパラメーターを True に設定する必要があります。これにより、後続のクエリが実行される前に、クエリのすべての結果がバッファにフェッチされるようになります。

cursor = cnx.cursor(buffered=True)

バッファパラメータを True に設定すると、「未読の結果が見つかりました」というエラーは発生しなくなります。

以上が`fetchone()` を使用すると、Python MySQL コネクタが「未読の結果が見つかりました」エラーをスローするのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。