Love beautiful code? We do too.
Trong MongoDB Documentation chính thức, một Covered Query là một truy vấn mà trong đó:
Khi tất cả các trường có mặc trong truy vấn là một phần của chỉ mục, MongoDB kết nối các điều kiện truy vấn và trả về kết quả bởi sử dụng cùng chỉ mục đó mà không nhìn vào bên trong Document. Khi các chỉ mục có mặt trong RAM, việc lấy dữ liệu từ các chỉ mục là nhanh hơn khi so sánh với khi lấy dữ liệu bằng cách quét toàn bộ các Document.
Để nghiên cứu về Covered Query, bạn theo dõi Document sau trong user collection:
{
"_id": ObjectId("53402597d852426020000002"),
"contact": "987654321",
"dob": "01-01-1991",
"gender": "M",
"name": "Tom Benzamin",
"user_name": "tombenzamin"
}
Đầu tiên, chúng ta tạo một chỉ mục phức hợp cho users collection trên các trường gender và user_name bởi sử dụng truy vấn sau:
>db.users.ensureIndex({gender:1,user_name:1})
Bây giờ, chỉ mục này sẽ bao phủ truy vấn sau:
>db.users.find({gender:"M"},{user_name:1,_id:0})
Có thể nói rằng, với truy vấn trên, MongoDB sẽ không đi vào tìm kiếm các Document trong cơ sở dữ liệu. Thay vào đó, nó sẽ lấy dữ liệu cần thiết từ dữ liệu đã lập chỉ mục, điều này sẽ giúp tiến trình xảy ra nhanh hơn rất nhiều.
Khi chỉ mục của chúng ta không bao gồm trường _id, chúng ta đã loại trừ nó một cách tường minh từ tập kết quả của truy vấn, bởi vì với MongoDB, theo mặc định thì sẽ trả về trường _id trong mỗi truy vấn. Vì thế, truy vấn sau sẽ không được phủ bên trong chỉ mục đã tạo ở trên:
>db.users.find({gender:"M"},{user_name:1})
Sau cùng, bạn nhớ rằng một chỉ mục không thể bao phủ một truy vấn nếu:
Hoclaptrinh.vn © 2017
From Coder With
Unpublished comment
Viết câu trả lời