색인 개요

이 섹션에서는 Cloud Firestore Enterprise 버전의 색인 생성을 설명합니다. Cloud Firestore Enterprise 버전은 기본적으로 색인을 생성하지 않습니다. 데이터베이스 성능을 개선하려면 가장 자주 사용되는 쿼리에 대한 색인을 만드세요.

색인은 데이터베이스 성능에 큰 영향을 미칩니다. 쿼리에 대한 색인이 있으면 데이터베이스는 스캔해야 하는 데이터 양을 줄이고 결과를 정렬하는 데 필요한 작업을 줄여 결과를 효율적으로 반환할 수 있습니다. 하지만 색인 항목은 스토리지 비용과 색인이 생성된 필드에 대한 쓰기 작업 중에 실행되는 작업량을 늘립니다.

버전 간 차이점

다음 표에서는 Cloud Firestore Standard 버전과 Cloud Firestore Enterprise 버전 간의 주요 색인 생성 차이점을 간략하게 보여줍니다.

기능 Cloud Firestore Standard 버전 Cloud Firestore Enterprise 버전
색인 생성 요구사항 모든 쿼리는 실행하려면 색인이 필요합니다. 이 요구사항으로 인해 일반적으로 쿼리 성능이 우수합니다. 쿼리에는 색인이 필요하지 않습니다. 색인이 생성되지 않은 읽기가 가능하여 프로토타입 제작에 어려움이 없습니다.
자동 색인 생성 기본적으로 문서 내의 모든 필드에 단일 필드 색인이 자동으로 생성됩니다. 자동 색인이 없습니다. 모든 색인을 수동으로 관리해야 합니다.
색인 밀도 기본적으로 희소입니다. 컬렉션 그룹의 문서는 색인이 생성된 모든 필드에 값이 포함된 경우에만 색인이 생성됩니다. 기본적으로 비희소입니다. 컬렉션 그룹의 모든 문서가 색인이 생성됩니다. 값이 없는 색인이 생성된 필드는 NULL로 설정됩니다. 동작은 희소 색인 옵션으로 변경할 수 있습니다.
지원되는 색인 유형 및 옵션
  • 단일 필드(자동 색인)
  • 복합 색인
  • 컬렉션 또는 컬렉션 그룹 범위
  • 배열에 포함
  • 벡터
  • 컬렉션 또는 컬렉션 그룹 범위
  • 비희소 또는 희소 색인 밀도
  • 배열에 포함
  • 벡터
  • 고유 색인

색인 정의 및 구조

색인은 다음과 같이 구성됩니다.

  • 컬렉션 ID
  • 지정된 컬렉션의 필드 목록
  • 각 필드의 순서(오름차순 또는 내림차순)

색인은 희소 또는 고유 옵션을 사용 설정할 수도 있습니다.

색인 순서

각 필드의 순서와 정렬 방향은 색인을 고유하게 정의합니다. 예를 들어 다음 색인은 서로 다른 두 개의 색인이며 서로 바꿔 사용할 수 없습니다.

컬렉션 필드
cities 국가(오름차순), 인구(내림차순)
cities 인구(내림차순), 국가(오름차순)

쿼리를 지원하는 색인을 만들 때는 쿼리와 동일한 순서로 필드를 포함합니다.

색인 밀도

기본적으로 색인 항목은 컬렉션의 모든 문서에서 데이터를 저장합니다. 이를 비희소 색인이라고 합니다. 문서에 색인에 지정된 필드가 포함되어 있는지 여부와 관계없이 문서에 색인 항목이 추가됩니다. 존재하지 않는 필드는 색인 항목을 생성할 때 NULL 값을 갖는 것으로 처리됩니다. 이 동작을 변경하려면 색인을 희소 색인으로 정의하면 됩니다.

희소 색인

희소 색인은 색인이 생성된 필드 중 하나 이상에 값(null 포함)이 포함된 컬렉션의 문서만 색인을 생성합니다. 희소 색인은 스토리지 비용을 줄이고 성능을 향상시킬 수 있습니다.

고유 색인

색인이 생성된 필드에 고유한 값을 적용하도록 고유 색인 옵션을 설정합니다. 여러 필드의 색인의 경우 값의 각 조합이 색인에서 고유해야 합니다. 데이터베이스는 중복된 값이 있는 색인 항목을 만들려고 하는 업데이트 및 삽입 작업을 거부합니다. 색인이 생성된 필드의 데이터에 중복 값이 포함되어 있고 고유 색인을 만들려고 하면 작업 세부정보에 오류 메시지가 표시되면서 색인 빌드가 실패합니다.

고유 색인에 없는 필드

고유 색인의 필드가 누락된 문서를 삽입하면 색인은 누락된 필드에 null 값을 설정합니다. 결과 색인 항목은 고유해야 합니다. 그렇지 않으면 작업이 실패합니다.

예를 들어 다음 색인의 경우

컬렉션 색인이 생성된 필드 쿼리 범위
cities 이름(오름차순) 컬렉션

문서 {"abbreviation": "LA"}를 컬렉션에 추가하면 고유 색인에서 namenull로 설정된 항목을 만듭니다. 그런 다음 문서 {"abbreviation": "NYC"}를 추가하려고 하면 고유 색인의 결과 항목이 동일하므로 작업이 실패합니다.

여러 필드가 있는 고유 색인에도 동일한 동작이 적용됩니다. 문서를 만들거나 업데이트할 때 색인이 생성된 필드가 누락되면 null로 설정되며 결과 색인 항목은 색인에서 고유해야 합니다.

색인 빌드 오류 문제 해결

색인을 관리할 때 색인 빌드 오류가 발생할 수 있습니다. 데이터베이스에서 데이터 문제가 발생하면 색인 생성 작업이 실패할 수 있습니다. 다음과 같은 이유로 색인 작업이 실패할 수 있습니다.

  • 색인 한도에 도달했습니다. 예를 들어 작업이 문서당 최대 색인 항목 수에 도달했을 수 있습니다. 색인 생성이 실패하면 오류 메시지가 표시됩니다. 색인 한도에 도달하지 않은 경우 색인 작업을 다시 시도하세요.
  • 고유 색인 옵션을 설정하고 색인이 생성된 필드의 데이터가 중복 색인 항목을 생성합니다. 계속하려면 데이터에서 중복된 값 조합을 삭제하세요.

다음 단계

색인 만들기 및 관리 방법 알아보기