ホームページ >バックエンド開発 >Python チュートリアル >SQLite で文字列コンストラクターなしで変数テーブル名を使用できますか?

SQLite で文字列コンストラクターなしで変数テーブル名を使用できますか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-08 18:15:021071ブラウズ

Can You Use Variable Table Names in SQLite Without String Constructors?

文字列コンストラクターを使用しない SQLite の変数テーブル名

SQLite では、脆弱な文字列に頼らずに変数テーブル名を使用できますかconstructors?

背景

SQLite データベース内のシミュレーション データをカタログ化するプロジェクトを考えてみましょう。効率と柔軟性を向上させるには、データの小さなサブセットに対して大きなテーブルをクエリすることを避けるために、スターごとにテーブルが必要です。ただし、SQL インジェクションのリスクがあるため、テーブル名に文字列コンストラクターを使用することはお勧めできません。

質問

文字列コンストラクターを利用せずに変数をテーブル名として使用することは可能ですか? 、 同族のto:

cursor.execute("CREATE TABLE (?) (etc etc)", self.name)

回答

残念ながら、SQLite ではテーブル名のパラメータ置換は許可されていません。

SQL インジェクションの軽減

SQL インジェクションの問題に対処するには、実装を検討してください。使用前にテーブル名をサニタイズする関数:

def sanitize_table_name(table_name):
    return ''.join(char for char in table_name if char.isalnum())

この関数は、句読点や空白などの特殊文字を削除してテーブル名をクリーンアップし、英数字の文字列を生成します。

使用例

消毒されたテーブルを使用するには名前:

sanitized_name = sanitize_table_name(self.name)
cursor.execute(f"CREATE TABLE StarFrame{sanitized_name} (etc etc)")

以上がSQLite で文字列コンストラクターなしで変数テーブル名を使用できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。