ホームページ > データベース > mysql チュートリアル > PostgreSQL でテーブル名を動的に生成するにはどうすればよいですか?

PostgreSQL でテーブル名を動的に生成するにはどうすればよいですか?

Patricia Arquette
リリース: 2024-12-30 15:46:09
オリジナル
411 人が閲覧しました

How Can I Dynamically Generate Table Names in PostgreSQL?

PostgreSQL でのテーブル名の動的生成

SQL では、動的クエリを作成できる PL/PgSQL バリアントを除き、動的 SQL はサポートされていません。クエリの結果を別のクエリのテーブル名として使用するには、PL/PgSQL EXECUTE ステートメントを利用できます。

次に例を示します。

DO
$$
BEGIN
EXECUTE format('CREATE TABLE %I AS SELECT * FROM backup', 'backup_' || to_char(CURRENT_DATE,'yyyy-mm-dd'));
END;
$$ LANGUAGE plpgsql;
ログイン後にコピー

の %I 形式指定子format 関数は、テーブル名を含む識別子を適切に引用符で囲み、quote_ident による明示的な引用符の必要性を排除します。

SQL インジェクションの脆弱性があるため、%L を使用した format(...) の代わりにリテラルに EXECUTE ... USING ステートメントを使用することを検討してください。テーブル/列名のような識別子の場合、%I パターンの簡潔さは依然として quote_ident の有用な代替手段となります。

以上がPostgreSQL でテーブル名を動的に生成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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