>데이터 베이스 >MySQL 튜토리얼 >PostgreSQL 배열 첨자를 1부터 시작하도록 재정규화하는 방법은 무엇입니까?

PostgreSQL 배열 첨자를 1부터 시작하도록 재정규화하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-09 12:03:56717검색

How to Renormalize PostgreSQL Array Subscripts to Start from 1?

PostgreSQL 배열 인덱스를 1부터 시작하도록 조정

PostgreSQL의 유연성 덕분에 표준 1에서 시작하지 않는 인덱스를 가진 배열이 허용됩니다. 예를 들어 다음 배열 요소는 5에서 7까지 인덱스가 지정됩니다.

<code class="language-sql">SELECT '[5:7]={1,2,3}'::int[];</code>

첫 번째 요소에 액세스하려면 인덱스 5를 사용해야 합니다.

<code class="language-sql">SELECT ('[5:7]={1,2,3}'::int[])[5];</code>

그러나 많은 사용자는 인덱스가 1부터 시작하는 배열을 선호합니다. 이를 달성하는 방법은 다음과 같습니다.

<code class="language-sql">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)];</code>

이렇게 하면 가장 낮은 인덱스에서 가장 높은 인덱스까지 배열 슬라이스를 추출하여 인덱싱을 효과적으로 재설정합니다.

공통 테이블 표현식(CTE)을 사용하여 더 읽기 쉬운 접근 방식:

<code class="language-sql">WITH cte(a) AS (SELECT '[5:7]={1,2,3}'::int[])
SELECT a[array_lower(a, 1):array_upper(a, 1)]
FROM cte;</code>

PostgreSQL 9.6 이상의 경우 슬라이스 사양에서 하한과 상한을 생략하는 간단한 방법이 있습니다.

<code class="language-sql">SELECT my_arr[:];</code>

이 예에서는 괄호를 사용하면 가독성이 향상됩니다.

<code class="language-sql">SELECT ( '[5:7]={1,2,3}'::int[] )[:];</code>

이 접근 방식은 효율적이며 9.6 이전 Postgres 버전에서도 잘 작동합니다.

위 내용은 PostgreSQL 배열 첨자를 1부터 시작하도록 재정규화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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