Rumah >pembangunan bahagian belakang >Tutorial Python >Mengapakah SQLite3 Melemparkan Ralat \'Bilangan Yang Tidak Betul Dibekalkan\' dan Bagaimana Saya Boleh Membetulkannya?

Mengapakah SQLite3 Melemparkan Ralat \'Bilangan Yang Tidak Betul Dibekalkan\' dan Bagaimana Saya Boleh Membetulkannya?

Barbara Streisand
Barbara Streisandasal
2024-12-06 10:24:13874semak imbas

Why Does SQLite3 Throw an

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn