Django クエリ実行で InterfaceError (0, '') が発生しました
Django ユーザーは永続的な「InterfaceError (0, '')」に遭遇する可能性があります" データベース操作を試行すると、特にサーバーの再起動後にエラーが発生します。このエラーは、グローバル カーソルの使用に起因します。
根本原因:
グローバル カーソルは、その名前が示すように、複数のカーソルにわたって開いたままになるデータベースへの永続的な接続です。操作。ただし、Django がよく使用する基盤となるデータベースである MySQL にはグローバル カーソルに関する問題があり、サーバーに中程度の負荷がかかると InterfaceError が発生する可能性があります。
解決策:
この問題を解決するには、生のクエリの実行を必要とする各メソッド内でカーソルを作成して閉じるように切り替えます。これにより、カーソルが特定の操作中にのみ開かれるようになり、グローバル カーソルに対する MySQL の不快感が回避されます。
実装:
次のコード スニペットを実装します:
cursor = connection.cursor()
cursor.execute(query)
cursor.close()
クエリを、実行したい生の SQL クエリに置き換えます。このアプローチを利用すると、クエリの実行直後にカーソルを閉じることができ、グローバル カーソルの使用が不要になり、InterfaceError.
が解決されます。免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3