> 데이터 베이스 > MySQL 튜토리얼 > PostgreSQL에서 인덱스된 열 정보를 추출하는 방법은 무엇입니까?

PostgreSQL에서 인덱스된 열 정보를 추출하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-12-29 21:57:16
원래의
602명이 탐색했습니다.

How to Extract Indexed Column Information in PostgreSQL?

PostgreSQL에서 인덱스된 열 정보 추출

PostgreSQL에서 인덱스에 포함된 열을 얻는 것은 데이터베이스 분석 및 성능 최적화를 위한 중요한 작업입니다. . MySQL의 SHOW INDEXES FOR 명령과 달리 PostgreSQL에는 이 정보를 검색하는 간단한 방법이 없습니다. 그러나 시스템 테이블과 집계 함수를 활용하면 유사한 결과를 얻을 수 있습니다.

인덱스된 열 및 인덱스 검색

다음 쿼리는 pg_class, pg_index, 인덱스 및 관련 세부 정보를 수집하기 위한 pg_attribute 시스템 테이블 열:

SELECT
    t.relname AS table_name,
    i.relname AS index_name,
    a.attname AS column_name
FROM
    pg_class t,
    pg_class i,
    pg_index ix,
    pg_attribute a
WHERE
    t.oid = ix.indrelid
    AND i.oid = ix.indexrelid
    AND a.attrelid = t.oid
    AND a.attnum = ANY(ix.indkey)
    AND t.relkind = 'r'
    AND t.relname LIKE 'table_name_pattern';
로그인 후 복사

이 쿼리는 지정된 테이블이나 테이블 그룹에 있는 모든 인덱스의 테이블 이름, 인덱스 이름 및 열 이름을 검색합니다.

인덱스 열 그룹화

각 인덱스로 인덱싱된 열의 통합 목록을 얻으려면 쿼리를 수정하여 결과를 그룹화하고 열을 집계할 수 있습니다. array_to_string() 함수를 사용하여 이름 지정:

SELECT
    t.relname AS table_name,
    i.relname AS index_name,
    array_to_string(array_agg(a.attname), ', ') AS column_names
FROM
    pg_class t,
    pg_class i,
    pg_index ix,
    pg_attribute a
WHERE
    t.oid = ix.indrelid
    AND i.oid = ix.indexrelid
    AND a.attrelid = t.oid
    AND a.attnum = ANY(ix.indkey)
    AND t.relkind = 'r'
    AND t.relname LIKE 'table_name_pattern'
GROUP BY
    t.relname,
    i.relname;
로그인 후 복사

이 쿼리는 테이블 이름, 인덱스 이름, 각 인덱스에 포함된 쉼표로 구분된 열 목록을 보여주는 표 형식 출력을 제공합니다. 이 정보는 인덱싱 전략을 이해하고 데이터베이스 성능을 최적화하는 데 유용할 수 있습니다.

위 내용은 PostgreSQL에서 인덱스된 열 정보를 추출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿