개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.04.24 16:02

pg_field_table 함수에 대한 도움을 요청합니다.

목록
  • 웹접근성장인 1일 전 2025.04.24 16:02
  • 8
    1
제가 현재 PostgreSQL에서 pg_field_table 함수를 사용하여 테이블의 필드를 조회하고자 합니다. 그러나 필드 이름이 여러 개의 스페이스바로 구분되어 있는 경우에 대해 어떻게 처리해야 하는지 궁금합니다. 예를 들어, "id name age"과 같은 필드 이름이 있는 테이블을 조회할 때, pg_field_table 함수는 어떻게 처리하나요?

혹시 이 경우 pg_field_table 함수를 사용하여 필드 이름을 분리하는 방법이 있을까요? 도와주세요.

    댓글목록

    profile_image
    나우호스팅  1일 전



    pg_field_table 함수는 PostgreSQL에서 테이블의 필드 이름을 조회하는 함수입니다. 그러나 필드 이름이 여러 개의 스페이스바로 구분되어 있는 경우 pg_field_table 함수는 이를 분리하지 못합니다.

    이러한 경우 pg_field_table 함수를 사용하여 필드 이름을 분리하는 방법은 없습니다. 그러나 PostgreSQL에서 제공하는 함수인 pg_get_identity()와 pg_get_constraintdef()와 같은 함수는 필드 이름을 분리하는 기능을 제공하지 않습니다.

    필드 이름을 분리하고자 하는 경우, PostgreSQL에서 제공하는 함수 대신에 SQL 문법을 사용하여 필드 이름을 분리할 수 있습니다. 예를 들어, 다음과 같이 SQL 문법을 사용하여 필드 이름을 분리할 수 있습니다.

    #hostingforum.kr
    sql
    
    SELECT 
    
        array_to_string(ARRAY["id", "name", "age"], ',') AS field_name
    
    FROM 
    
        pg_attribute
    
    WHERE 
    
        attrelid = '테이블명'::regclass
    
    AND 
    
        attisdropped = FALSE;
    
    


    이 SQL 문법은 pg_attribute 테이블에서 테이블의 필드 이름을 조회하고, array_to_string 함수를 사용하여 필드 이름을 분리합니다.

    또한, PostgreSQL 10 버전 이상부터는 pg_get_expr 함수를 사용하여 필드 이름을 분리할 수 있습니다.

    #hostingforum.kr
    sql
    
    SELECT 
    
        pg_get_expr(attrelid, attname) AS field_name
    
    FROM 
    
        pg_attribute
    
    WHERE 
    
        attrelid = '테이블명'::regclass
    
    AND 
    
        attisdropped = FALSE;
    
    


    이 SQL 문법은 pg_attribute 테이블에서 테이블의 필드 이름을 조회하고, pg_get_expr 함수를 사용하여 필드 이름을 분리합니다.

    이러한 방법을 사용하여 필드 이름을 분리할 수 있습니다.

    2025-04-24 16:03

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 14,255건 / 16 페이지

검색

게시물 검색