ArangoDB-데이터 모델 및 모델링
이 장에서는 다음 주제에 초점을 맞출 것입니다.
- 데이터베이스 상호 작용
- 데이터 모델
- 데이터 검색
ArangoDB는 문서 기반 데이터 모델과 그래프 기반 데이터 모델을 지원합니다. 먼저 문서 기반 데이터 모델을 설명하겠습니다.
ArangoDB의 문서는 JSON 형식과 매우 유사합니다. 문서에는 0 개 이상의 속성이 포함되며 각 속성과 함께 값이 첨부됩니다. 값은 숫자, 부울 또는 널, 리터럴 문자열과 같은 원자 유형이거나 포함 된 문서 / 객체 또는 배열과 같은 복합 데이터 유형입니다. 배열 또는 하위 개체는 이러한 데이터 유형으로 구성 될 수 있으며, 이는 단일 문서가 중요하지 않은 데이터 구조를 나타낼 수 있음을 의미합니다.
더 나아가 계층 구조에서 문서는 컬렉션으로 정렬되며, 문서에는 문서가 없거나 (이론상) 둘 이상의 문서가 포함될 수 있습니다. 문서를 행과 컬렉션을 테이블과 비교할 수 있습니다 (여기에서 테이블과 행은 관계형 데이터베이스 관리 시스템-RDBMS의 항목을 나타냄).
그러나 RDBMS에서 열 정의는 이러한 정의 스키마를 호출하여 레코드를 테이블에 저장하기위한 전제 조건입니다. 그러나 새로운 기능으로서 ArangoDB는 스키마가 없습니다. 문서가 가질 속성을 지정해야 할 사전 이유가 없습니다.
그리고 RDBMS와 달리 각 문서는 다른 문서와 완전히 다른 방식으로 구성 될 수 있습니다. 이러한 문서는 하나의 컬렉션에 함께 저장할 수 있습니다. 실제로 컬렉션의 문서간에 공통적 인 특성이있을 수 있지만 데이터베이스 시스템, 즉 ArangoDB 자체는 사용자를 특정 데이터 구조에 바인딩하지 않습니다.
이제 우리는 ArangoDB의 [graph data model], 두 종류의 컬렉션이 필요합니다. 첫 번째는 문서 컬렉션 (그룹 이론 언어의 정점 컬렉션이라고 함)이고 두 번째는 에지 컬렉션입니다. 이 두 유형 사이에는 미묘한 차이가 있습니다. Edge 컬렉션도 문서를 저장하지만 두 가지 고유 속성을 포함하는 것이 특징입니다._from 과 _to문서 간의 관계를 생성합니다. 실제로 문서 (가장자리 읽기)는 두 문서 (정점 읽기)를 연결하며 둘 다 해당 컬렉션에 저장됩니다. 이 아키텍처는 레이블을 가질 수있을뿐만 아니라 문서 자체와 같은 완전한 JSON이 될 수있는 에지를 제외하고 레이블이 지정된 방향성 그래프의 그래프 이론적 개념에서 파생되었습니다.
새로운 데이터를 계산하거나 문서를 삭제하거나 조작하기 위해 주어진 기준에 따라 문서를 선택하거나 필터링하는 쿼리가 사용됩니다. "예제 쿼리"처럼 간단하거나 "조인"만큼 복잡하든 쿼리는 AQL-ArangoDB 쿼리 언어로 코딩됩니다.