관계형 모델의 원칙 중 하나는 속성이 관계는 원자적입니다.포스트그레스이 제한이 없습니다. 속성 자체에는 다음이 포함될 수 있습니다. 쿼리 언어에서 액세스할 수 있는 하위 값입니다. 에 대한 예를 들어 기본 윈 토토인 속성을 생성할 수 있습니다. 유형.
포스트그레다음의 속성을 허용합니다. 고정 길이 또는 가변 길이로 정의되는 인스턴스 다차원 윈 토토. 모든 기본 유형 또는 사용자 정의 윈 토토 유형을 생성할 수 있습니다. 사용법을 설명하기 위해 먼저 기본 유형의 윈 토토이 있는 클래스입니다.
테이블 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 = '빌';
+------+
|일정 |
+------+
|"회의","" |
+------+