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 genderuser_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:

  • Bất kỳ trường đã được lập chỉ mục nào là một mảng

  • Bất kỳ trường đã được lập chỉ mục nào là một Subdocument

Last updated