Rumah >pembangunan bahagian belakang >Tutorial Python >Mengapakah SQLite3 Melemparkan Ralat \'Bilangan Yang Tidak Betul Dibekalkan\' dan Bagaimana Saya Boleh Membetulkannya?
Menyelesaikan masalah Ralat "Nombor Pengikatan yang Tidak Betul" dalam SQLite3
Apabila memasukkan data ke dalam pangkalan data menggunakan SQLite3, pengaturcara mungkin menghadapi ralat "Bilangan pengikatan yang salah dibekalkan." Ralat ini menandakan ketidakpadanan antara bilangan nilai yang dijangkakan oleh pernyataan SQL dan bilangan argumen yang disediakan.
Dalam coretan kod yang diberikan, percubaan dibuat untuk memasukkan rentetan ke dalam pangkalan data menggunakan INSERT INTO images penyataan NILAI(?). Walau bagaimanapun, input yang disediakan, iaitu rentetan, dianggap sebagai nilai ikatan berbilang kerana ketiadaan koma. Untuk menyelesaikan isu ini, pastikan hujah yang dihantar kepada kaedah cursor.execute() ialah tuple, dilambangkan dengan koma belakang:
cursor.execute('INSERT INTO images VALUES(?)', (img,))
Dengan melampirkan img dalam tuple, ia dianggap sebagai satu nilai ikatan, menghalang ralat daripada berlaku.
Corak ini, di mana koma mengekor diperlukan untuk menukar satu nilai kepada tuple, adalah perangkap biasa dalam pengaturcaraan Python. Walaupun ia mungkin kelihatan tidak perlu, ia adalah langkah penting untuk mengelakkan ralat masa jalan.
Atas ialah kandungan terperinci Mengapakah SQLite3 Melemparkan Ralat \'Bilangan Yang Tidak Betul Dibekalkan\' dan Bagaimana Saya Boleh Membetulkannya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!