Covered Query trong MongoDB
Covered Query là gì? 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 ...
Covered Query là gì?
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.
Sử dụng Covered Query trong MongoDB
Để 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:
Follow fanpage của team https://www.facebook.com/vietjackteam/ hoặc facebook cá nhân Nguyễn Thanh Tuyền https://www.facebook.com/tuyen.vietjack để tiếp tục theo dõi các loạt bài mới nhất về Java,C,C++,Javascript,HTML,Python,Database,Mobile.... mới nhất của chúng tôi.
Các bài học lập trình MongoDB phổ biến khác tại code24h: