Home > Database > Mysql Tutorial > How Can I Dynamically Generate Table Names in PostgreSQL?

How Can I Dynamically Generate Table Names in PostgreSQL?

Patricia Arquette
Release: 2024-12-30 15:46:09
Original
427 people have browsed it

How Can I Dynamically Generate Table Names in PostgreSQL?

Dynamically Generating Table Names in PostgreSQL

In SQL, dynamic SQL is not supported except in the PL/PgSQL variant, which can create dynamic queries. To use the result of a query as a table name in another query, you can utilize the PL/PgSQL EXECUTE statement.

Here's an example:

DO
$$
BEGIN
EXECUTE format('CREATE TABLE %I AS SELECT * FROM backup', 'backup_' || to_char(CURRENT_DATE,'yyyy-mm-dd'));
END;
$$ LANGUAGE plpgsql;
Copy after login

The %I format specifier in the format function properly quotes identifiers, including table names, eliminating the need for explicit quoting with quote_ident.

To prevent SQL injection vulnerabilities, consider using the EXECUTE ... USING statement for literals instead of format(...) with %L. For identifiers like table/column names, the conciseness of the %I pattern remains a useful alternative to quote_ident.

The above is the detailed content of How Can I Dynamically Generate Table Names in PostgreSQL?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template