Tổng quan về chỉ mục

Phần này mô tả quy trình lập chỉ mục cho phiên bản Firestore Enterprise. Theo mặc định, phiên bản Firestore Enterprise không tạo chỉ mục nào. Để giảm chi phí và cải thiện hiệu suất cơ sở dữ liệu, hãy tạo chỉ mục cho các truy vấn thường dùng nhất.

Chỉ mục có tác động lớn đến hiệu suất của cơ sở dữ liệu. Nếu có chỉ mục cho một truy vấn, cơ sở dữ liệu có thể trả về kết quả một cách hiệu quả bằng cách giảm lượng dữ liệu cần quét và giảm công việc cần thiết để sắp xếp kết quả. Tuy nhiên, các mục trong chỉ mục làm tăng chi phí lưu trữ và lượng công việc được thực hiện trong quá trình ghi trên các trường được lập chỉ mục.

Định nghĩa và cấu trúc chỉ mục

Một chỉ mục bao gồm những thành phần sau:

  • mã bộ sưu tập
  • danh sách các trường trong bộ sưu tập đã cho
  • thứ tự (tăng dần hoặc giảm dần) cho từng trường

Chỉ mục cũng có thể bật các tuỳ chọn thưa thớt hoặc duy nhất.

Thứ tự chỉ mục

Thứ tự và hướng sắp xếp của từng trường xác định duy nhất chỉ mục. Ví dụ: các chỉ mục sau đây là 2 chỉ mục riêng biệt và không thể thay thế cho nhau:

Bộ sưu tập Trường
thành phố quốc gia (tăng dần), dân số (giảm dần)
thành phố dân số (giảm dần), quốc gia (tăng dần)

Khi tạo chỉ mục để hỗ trợ truy vấn, hãy đưa các trường vào theo cùng thứ tự như truy vấn của bạn.

Mật độ chỉ mục

Theo mặc định, các mục trong chỉ mục lưu trữ dữ liệu từ tất cả tài liệu trong một bộ sưu tập. Đây được gọi là chỉ mục không thưa thớt. Một mục trong chỉ mục sẽ được thêm cho một tài liệu bất kể tài liệu đó có chứa bất kỳ trường nào được chỉ định trong chỉ mục hay không. Các trường không tồn tại được coi là có giá trị NULL khi tạo các mục trong chỉ mục. Để thay đổi hành vi này, bạn có thể xác định chỉ mục là chỉ mục thưa thớt.

Chỉ mục thưa thớt

Chỉ mục thưa thớt chỉ lập chỉ mục các tài liệu trong bộ sưu tập có chứa giá trị (bao gồm cả giá trị rỗng) cho ít nhất một trong các trường được lập chỉ mục. Chỉ mục thưa thớt giúp giảm chi phí lưu trữ và có thể cải thiện hiệu suất.

Chỉ mục duy nhất

Đặt tuỳ chọn chỉ mục duy nhất để thực thi các giá trị duy nhất cho các trường được lập chỉ mục. Đối với các chỉ mục trên nhiều trường, mỗi tổ hợp giá trị phải là duy nhất trong chỉ mục. Cơ sở dữ liệu sẽ từ chối mọi thao tác cập nhật và chèn nhằm tạo các mục trong chỉ mục có giá trị trùng lặp. Nếu dữ liệu của các trường được lập chỉ mục chứa các giá trị trùng lặp và bạn cố gắng tạo chỉ mục duy nhất, thì quá trình tạo chỉ mục sẽ không thành công và bạn sẽ thấy thông báo lỗi trong phần chi tiết thao tác.

Các trường không có trong chỉ mục duy nhất

Nếu bạn chèn một tài liệu có các trường bị thiếu cho chỉ mục duy nhất, thì chỉ mục sẽ đặt giá trị null cho các trường bị thiếu. Mục trong chỉ mục kết quả phải là duy nhất, nếu không thao tác sẽ không thành công.

Ví dụ: với chỉ mục này:

Bộ sưu tập Các trường được lập chỉ mục Phạm vi truy vấn
thành phố tên (tăng dần) Bộ sưu tập

Nếu bạn thêm tài liệu {"abbreviation": "LA"} vào bộ sưu tập, thì chỉ mục duy nhất sẽ tạo một mục có name được đặt thành null. Nếu sau đó bạn cố gắng thêm tài liệu {"abbreviation": "NYC"}, thì thao tác sẽ không thành công vì mục kết quả cho chỉ mục duy nhất là giống nhau.

Hành vi tương tự cũng áp dụng cho các chỉ mục duy nhất có nhiều trường. Khi tạo hoặc cập nhật tài liệu, các trường được lập chỉ mục bị thiếu sẽ được đặt thành null và mục trong chỉ mục kết quả phải là duy nhất trong chỉ mục.

Khắc phục lỗi tạo chỉ mục

Bạn có thể gặp lỗi tạo chỉ mục khi quản lý chỉ mục. Thao tác lập chỉ mục có thể không thành công nếu cơ sở dữ liệu gặp vấn đề với dữ liệu. Thao tác lập chỉ mục có thể không thành công vì những lý do sau:

  • Bạn đã đạt đến giới hạn về số lượng chỉ mục. Ví dụ: thao tác có thể đã đạt đến số lượng mục trong chỉ mục tối đa cho mỗi tài liệu. Nếu quá trình tạo chỉ mục không thành công, bạn sẽ thấy thông báo lỗi. Nếu bạn chưa đạt đến giới hạn về số lượng chỉ mục, hãy thử lại thao tác lập chỉ mục.
  • Bạn đặt tuỳ chọn chỉ mục duy nhất và dữ liệu của các trường được lập chỉ mục sẽ tạo các mục trong chỉ mục trùng lặp. Để tiếp tục, hãy xoá các tổ hợp giá trị trùng lặp khỏi dữ liệu.

Bước tiếp theo

Tìm hiểu cách tạo và quản lý chỉ mục.