ホームページ > バックエンド開発 > Python チュートリアル > Python 内の SQL ステートメントで変数を安全に使用するにはどうすればよいですか?

Python 内の SQL ステートメントで変数を安全に使用するにはどうすればよいですか?

Linda Hamilton
リリース: 2025-01-01 09:03:10
オリジナル
969 人が閲覧しました

How Can I Safely Use Variables in SQL Statements within Python?

Python の SQL ステートメントでの変数の使用

この記事では、Python の SQL ステートメントでの変数の使用に関する一般的な問題の解決策を提供します。次の Python コード:

cursor.execute("INSERT INTO table VALUES var1, var2, var3")
ログイン後にコピー

は、変数名がクエリ テキストの一部として含まれているため、エラーで失敗します。これを解決するには、次の構文を使用します。

cursor.execute("INSERT INTO table VALUES (%s, %s, %s)", (var1, var2, var3))
ログイン後にコピー

この解決策では、SQL ステートメント内の変数名がプレースホルダー (%s) に置き換えられます。次に、パラメーターはタプル (var1、var2、var3) として渡されます。単一のパラメータを渡す場合、タプルはカンマで終わる必要があることに注意してください。

このメソッドを使用すると、データベース API が変数の適切なエスケープと引用を確実に処理します。文字列フォーマット演算子 % はエスケープや引用符を実行しないため、使用しないことが重要です。これにより、SQL インジェクションなどのセキュリティ上の脆弱性が発生する可能性があります。

以上がPython 内の SQL ステートメントで変数を安全に使用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート