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

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

Patricia Arquette
Patricia Arquetteオリジナル
2024-12-30 15:46:09399ブラウズ

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 サイトの他の関連記事を参照してください。

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