PostgreSQL 배열 인덱스를 1부터 시작하도록 조정
PostgreSQL의 유연성 덕분에 표준 1에서 시작하지 않는 인덱스를 가진 배열이 허용됩니다. 예를 들어 다음 배열 요소는 5에서 7까지 인덱스가 지정됩니다.
SELECT '[5:7]={1,2,3}'::int[];
첫 번째 요소에 액세스하려면 인덱스 5를 사용해야 합니다.
SELECT ('[5:7]={1,2,3}'::int[])[5];
그러나 많은 사용자는 인덱스가 1부터 시작하는 배열을 선호합니다. 이를 달성하는 방법은 다음과 같습니다.
SELECT ('[5:7]={1,2,3}'::int[])[array_lower('[5:7]={1,2,3}'::int[], 1):array_upper('[5:7]={1,2,3}'::int[], 1)];
이렇게 하면 가장 낮은 인덱스에서 가장 높은 인덱스까지 배열 슬라이스를 추출하여 인덱싱을 효과적으로 재설정합니다.
공통 테이블 표현식(CTE)을 사용하여 더 읽기 쉬운 접근 방식:
WITH cte(a) AS (SELECT '[5:7]={1,2,3}'::int[]) SELECT a[array_lower(a, 1):array_upper(a, 1)] FROM cte;
PostgreSQL 9.6 이상의 경우 슬라이스 사양에서 하한과 상한을 생략하는 간단한 방법이 있습니다.
SELECT my_arr[:];
이 예에서는 괄호를 사용하면 가독성이 향상됩니다.
SELECT ( '[5:7]={1,2,3}'::int[] )[:];
이 접근 방식은 효율적이며 9.6 이전 Postgres 버전에서도 잘 작동합니다.
위 내용은 PostgreSQL 배열 첨자를 1부터 시작하도록 재정규화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!