Beim Versuch, sich vor SQL-Injections zu schützen, ist ein Entwickler bei der Verwendung von SQLite3 mit Python 2.5 auf einen Fehler gestoßen. Bei Verwendung des empfohlenen „?“ Nachdem sie Parameter ersetzt hatten, um Injektionen zu verhindern, standen sie vor dem folgenden Dilemma:
sqlite3.ProgrammingError: Incorrect number of bindings supplied. The current statement uses 1, and there are 8 supplied.
Dieses Problem schien auf die ursprüngliche Erstellung der Datenbank zurückzuführen zu sein, die acht Bindungen enthielt. Die Verwendung der weniger sicheren „%s“-Ersetzung für jeden Elementnamen löste das Problem jedoch.
for item in self.inventory_names: self.cursor.execute("SELECT weight FROM Equipment WHERE name = '%s'" % item) self.cursor.close()
Die Lösung dieser Verwirrung liegt darin, zu verstehen, dass die Cursor.execute()-Methode eine Sequenz als zweite benötigt Parameter. In diesem Fall stellte der Entwickler eine Zeichenfolge bereit, die zufällig acht Zeichen lang war. Um dies zu beheben, sollte die folgende Codeänderung implementiert werden:
self.cursor.execute("SELECT weight FROM Equipment WHERE name = ?", [item])
Durch die Einhaltung dieser Parameterspezifikation kann das Problem effektiv behoben werden, was einen sicheren und effizienten Datenabruf von SQLite3 ermöglicht.
Das obige ist der detaillierte Inhalt vonWarum wird bei der Verwendung von SQLite3 in Python die „Falsche Anzahl der bereitgestellten Bindungen' bei Verwendung der „?'-Parametersubstitution angezeigt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!