ホームページ >バックエンド開発 >Python チュートリアル >SQLite3 が「指定されたバインディングの数が正しくありません」エラーをスローするのはなぜですか?それを修正するにはどうすればよいですか?
SQLite3 の「指定されたバインディングの数が正しくありません」エラーのトラブルシューティング
SQLite3 を使用してデータベースにデータを挿入すると、プログラマがエラーに遭遇する可能性があります「提供されたバインディングの数が正しくありません。」このエラーは、SQL ステートメントで予期される値の数と指定された引数の数が一致していないことを示します。
指定されたコード スニペットでは、INSERT INTO イメージを使用してデータベースに文字列を挿入しようとしています。 VALUES(?) ステートメント。ただし、指定された文字列である入力は、カンマがないため、複数のバインド値として扱われます。この問題を解決するには、cursor.execute() メソッドに渡される引数が末尾のカンマで示されるタプルであることを確認します。
cursor.execute('INSERT INTO images VALUES(?)', (img,))
img をタプル内で囲むことにより、単一のものとして扱われます。
単一の値をタプルに変換するために末尾のカンマが必要なこのパターンは、 Python プログラミングでよくある落とし穴。不必要に思えるかもしれませんが、実行時エラーを回避するためには重要な手順です。
以上がSQLite3 が「指定されたバインディングの数が正しくありません」エラーをスローするのはなぜですか?それを修正するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。