이 문서는 지원되지 않는 PostgreSQL 버전에 대한 것입니다.
당신은 다음과 같은 페이지를 보고 싶을 수도 있습니다.현재버전 또는 위에 나열된 다른 지원 버전 중 하나를 사용하세요.

비원자 값

관계형 모델의 원칙 중 하나는 속성이 관계는 원자적입니다.포스트그레스이 제한이 없습니다. 속성 자체에는 다음이 포함될 수 있습니다. 쿼리 언어에서 액세스할 수 있는 하위 값입니다. 에 대한 예를 들어 기본 윈 토토인 속성을 생성할 수 있습니다. 유형.

윈 토토

포스트그레다음의 속성을 허용합니다. 고정 길이 또는 가변 길이로 정의되는 인스턴스 다차원 윈 토토. 모든 기본 유형 또는 사용자 정의 윈 토토 유형을 생성할 수 있습니다. 사용법을 설명하기 위해 먼저 기본 유형의 윈 토토이 있는 클래스입니다.

테이블 SAL_EMP 생성(
    이름 텍스트,
    pay_by_quarter int4[],
    일정 텍스트[][]
);

위 쿼리는 다음과 함께 SAL_EMP라는 클래스를 생성합니다.텍스트문자열(이름), 1차원 윈 토토int4(pay_by_quarter), 이는 직원의 급여를 분기별 및 2차원으로 나타냅니다. 윈 토토텍스트(일정), 이는 다음을 나타냅니다. 직원의 주간 일정. 이제 좀 해보겠습니다삽입s; 윈 토토에 추가할 때 우리는 값을 중괄호로 묶고 쉼표로 구분합니다. 만약에 아시죠C, 이는 구문과 다르지 않습니다. 구조 초기화를 위해.

SAL_EMP에 삽입
    VALUES('빌',
    '10000, 10000, 10000, 10000',
    '"회의", "점심", ');

SAL_EMP에 삽입
    VALUES('캐롤',
    '20000, 25000, 25000, 25000',
    '"대화", "상담", "회의"');
기본적으로,포스트그레스사용 윈 토토에 대한 "1부터 시작하는" 번호 매기기 규칙입니다. n개 요소로 구성된 윈 토토은 array[1]로 시작하고 array[n]으로 끝납니다. 이제 SAL_EMP에 대해 몇 가지 쿼리를 실행할 수 있습니다. 먼저, 방법을 보여드리겠습니다. 한 번에 윈 토토의 단일 요소에 액세스합니다. 이 쿼리는 검색합니다 2분기에 급여가 변경된 직원의 이름:
이름 선택
    SAL_EMP에서
    WHERE SAL_EMP.pay_by_quarter[1] <
    SAL_EMP.pay_by_quarter[2];

+------+
|이름 |
+------+
|캐롤 |
+------+

이 쿼리는 모든 직원의 3분기 급여를 검색합니다:

SAL_EMP에서 SAL_EMP.pay_by_quarter[3] 선택;

+---------------+
|pay_by_quarter |
+---------------+
|10000 |
+---------------+
|25000 |
+---------------+

우리는 또한 윈 토토의 임의의 조각이나 하위 윈 토토에 접근할 수 있습니다. 이 쿼리는 Bill의 일정에서 첫 번째 항목을 검색합니다. 한 주의 첫 이틀.

SELECT SAL_EMP.일정[1:2][1:1]
    SAL_EMP에서
    WHERE SAL_EMP.name = '빌';

+------+
|일정 |
+------+
|"회의","" |
+------+