Apabila Menggunakan SQLite3 dalam Python, Mengapakah \'Bilangan Ikatan yang Tidak Bekal\' Apabila Menggunakan \'?\' Penggantian Parameter?

Mary-Kate Olsen
Lepaskan: 2024-10-19 15:30:03
asal
152 orang telah melayarinya

When Using SQLite3 in Python, Why

SQLite Parameter Substitution Conundrum

Dalam percubaan untuk melindungi daripada suntikan SQL, pembangun mengalami ralat semasa menggunakan SQLite3 dengan Python 2.5. Apabila menggunakan "?" yang disyorkan penggantian parameter untuk mengelakkan suntikan, mereka menghadapi dilema berikut:

sqlite3.ProgrammingError: Incorrect number of bindings supplied. The current statement uses 1, and there are 8 supplied.
Salin selepas log masuk

Isu ini nampaknya berpunca daripada penciptaan awal pangkalan data, yang mengandungi lapan pengikatan. Walau bagaimanapun, menggunakan penggantian "%s" yang kurang selamat untuk setiap nama item telah menyelesaikan masalah.

for item in self.inventory_names:
    self.cursor.execute("SELECT weight FROM Equipment WHERE name = '%s'" % item)
    self.cursor.close()
Salin selepas log masuk

Penyelesaian kepada kebingungan ini terletak pada pemahaman bahawa kaedah Cursor.execute() memerlukan urutan sebagai yang kedua parameter. Dalam keadaan ini, pembangun menyediakan rentetan yang kebetulan mempunyai lapan aksara panjang. Untuk membetulkan perkara ini, pengubahsuaian kod berikut harus dilaksanakan:

self.cursor.execute("SELECT weight FROM Equipment WHERE name = ?", [item])
Salin selepas log masuk

Dengan mematuhi spesifikasi parameter ini, isu ini boleh ditangani dengan berkesan, membolehkan pengambilan data yang selamat dan cekap daripada SQLite3.

Atas ialah kandungan terperinci Apabila Menggunakan SQLite3 dalam Python, Mengapakah \'Bilangan Ikatan yang Tidak Bekal\' Apabila Menggunakan \'?\' Penggantian Parameter?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
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
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!