Python MySQL Connector: Hasil Belum Dibaca Ditemui Apabila Menggunakan Fetchone
Dalam Python, menghadapi ralat "Hasil belum dibaca ditemui" semasa menggunakan penyambung MySQL sering berpunca daripada menggunakan fungsi fetchone() tanpa menggunakan semua hasil dengan betul. Ralat ini berlaku apabila melaksanakan pertanyaan berikutnya tanpa terlebih dahulu mengambil dan menggunakan sebarang hasil sedia ada daripada pertanyaan sebelumnya.
Untuk menyelesaikan isu ini, pastikan semua hasil daripada pertanyaan yang dilaksanakan diambil dan digunakan sebelum beralih ke pertanyaan berikutnya. Satu pendekatan ialah menggunakan kaedah cursor.fetchall() untuk mendapatkan semua keputusan dan mengosongkan penimbal. Ini boleh dicapai dengan menambah blok cuba/kecuali untuk menangkap dan mengendalikan sebarang Ralat Antaramuka.
Walau bagaimanapun, dalam senario khusus ini, isunya terletak pada kekurangan kursor penimbal. Secara lalai, kursor dicipta tanpa penimbalan. Mendayakan penimbalan memastikan bahawa semua hasil daripada pertanyaan diambil awal dan berada dalam memori pelanggan. Untuk mendayakan penimbalan, mulakan kursor dengan parameter buffered=True:
cursor = cnx.cursor(buffered=True)
Dengan kursor penimbal, fetchone() akan mengembalikan satu baris daripada set hasil pra-ambil, menghapuskan ralat yang disebabkan oleh hasil yang belum dibaca . Adalah penting untuk ambil perhatian bahawa kursor penimbal mungkin menggunakan lebih banyak memori, terutamanya apabila bekerja dengan set hasil yang besar. Pertimbangkan untuk menggunakan kursor tidak buffer untuk prestasi yang lebih baik dalam kes sedemikian. Ingat untuk mengambil dan menggunakan semua hasil secara manual untuk mengelakkan ralat "Hasil belum dibaca ditemui".
Atas ialah kandungan terperinci Mengapa Saya Mendapat Ralat \'Belum Dibaca Ditemui\' dengan Penyambung MySQL Python dan Bagaimana Saya Boleh Membetulkannya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!