「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Python で SQLite3 を使用する場合、「?」パラメータ置換を使用すると「指定されたバインディングの数が正しくありません」が発生するのはなぜですか?

Python で SQLite3 を使用する場合、「?」パラメータ置換を使用すると「指定されたバインディングの数が正しくありません」が発生するのはなぜですか?

2024 年 11 月 7 日に公開
ブラウズ:988

When Using SQLite3 in Python, Why \

SQLite パラメータ置換の難問

SQL インジェクションから保護しようとして、開発者が Python 2.5 で SQLite3 を使用中にエラーが発生しました。推奨の「?」を採用する場合インジェクションを防ぐためにパラメータ置換を行うと、次のジレンマに直面しました:

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

この問題は、8 つのバインディングを含むデータベースの最初の作成に起因しているようです。ただし、各項目名に安全性の低い「%s」置換を使用すると、問題は解決されました。

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

この困惑の解決策は、Cursor.execute() メソッドの 2 番目のパラメーターとしてシーケンスが必要であることを理解することにあります。この例では、開発者はたまたま 8 文字の長さの文字列を提供していました。これを修正するには、次のコード変更を実装する必要があります:

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

このパラメータに準拠することにより仕様に準拠すると、問題は効果的に解決され、SQLite3.

から安全かつ効率的にデータを取得できるようになります。
リリースステートメント この記事は次の場所に転載されています: 1729322955 権利侵害がある場合は、[email protected] に連絡して削除してください。
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3