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

Làm thế nào để sử dụng hoặc toán tử trong MongoDB để tìm nạp các bản ghi trên cơ sở tồn tại?

Để tìm nạp các bản ghi với $ hoặc trên cơ sở tồn tại, hãy sử dụng $ hoặc cùng với $ tồn tại. Hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -

>db.demo185.insertOne({_id:101,details:{Name:"Chris",Score:78,Subjects:{"Name":"MySQL"}}});
{ "acknowledged" : true, "insertedId" : 101 }
> db.demo185.insertOne({_id:102,details:{Name:"Bob",Score:78}});
{ "acknowledged" : true, "insertedId" : 102 }
>db.demo185.insertOne({_id:103,details:{Name:"David",Score:78,Subjects:{"Name":"MongoDB"}}});
{ "acknowledged" : true, "insertedId" : 103 }

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.demo185.find();

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

{ "_id" : 101, "details" : { "Name" : "Chris", "Score" : 78, "Subjects" : { "Name" : "MySQL" } } }
{ "_id" : 102, "details" : { "Name" : "Bob", "Score" : 78 } }
{ "_id" : 103, "details" : { "Name" : "David", "Score" : 78, "Subjects" : { "Name" : "MongoDB" } } }

Sau đây là truy vấn sử dụng hoặc toán tử trong MongoDB -

> db.demo185.find({
...   "$or": [
...      { "details.Subjects.Name": { "$exists": true } },
...      { "details.Subjects.Name": { "$exists": true } }
...   ]
... })

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

{ "_id" : 101, "details" : { "Name" : "Chris", "Score" : 78, "Subjects" : { "Name" : "MySQL" } } }
{ "_id" : 103, "details" : { "Name" : "David", "Score" : 78, "Subjects" : { "Name" : "MongoDB" } } }