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
Lepaskan: 2024-12-06 10:24:13
asal
925 orang telah melayarinya

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,))
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan