Computer >> Máy Tính >  >> Lập trình >> MongoDB

Truy vấn MongoDB để lấy danh sách tên cụ thể từ các tài liệu trong đó giá trị của một trường là một mảng

Đối với điều này, hãy sử dụng $ all. Toán tử $ all chọn các tài liệu trong đó giá trị của một trường là một mảng chứa tất cả các phần tử được chỉ định. Hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -

> db.demo642.insertOne(
...    {
...       _id:1,
...       ListOfNames:["Robert","John"]
...    }
... );
{ "acknowledged" : true, "insertedId" : 1 }
> db.demo642.insertOne( { _id:2, ListOfNames:["Robert","Chris"] } );
{ "acknowledged" : true, "insertedId" : 2 }

Hiển thị tất cả các tài liệu từ một bộ sưu tập với sự trợ giúp của phương thức find () -

> db.demo642.find();

Điều này sẽ tạo ra kết quả sau -

{ "_id" : 1, "ListOfNames" : [ "Robert", "John" ] }
{ "_id" : 2, "ListOfNames" : [ "Robert", "Chris" ] }

Sau đây là truy vấn để lấy danh sách tên cụ thể từ các tài liệu trong đó giá trị của một trường là một mảng -

> db.demo642.find({ListOfNames: {
...    $all: [ "Chris", "Robert" ]
... }})

Điều này sẽ tạo ra kết quả sau -

{ "_id" : 2, "ListOfNames" : [ "Robert", "Chris" ] }