>데이터 베이스 >MySQL 튜토리얼 >PostgreSQL에서 테이블 이름을 동적으로 생성하려면 어떻게 해야 합니까?

PostgreSQL에서 테이블 이름을 동적으로 생성하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-30 15:46:09402검색

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.