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

Truy vấn MongoDB để tìm nạp một tài liệu không có một trường cụ thể?

Để kiểm tra sự tồn tại, hãy sử dụng $ being. Hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -

> db.demo234.insertOne({"FirstName":"Chris","LastName":"Brown","Age":24});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e418a50f4cebbeaebec5148")
}
> db.demo234.insertOne({"FirstName":"David","LastName":"Miller"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e418a5ff4cebbeaebec5149")
}
> db.demo234.insertOne({"FirstName":"John","LastName":"Smith",Age:34});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e418a70f4cebbeaebec514a")
}

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

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

{ "_id" : ObjectId("5e418a50f4cebbeaebec5148"), "FirstName" : "Chris", "LastName" : "Brown", "Age" : 24 }
{ "_id" : ObjectId("5e418a5ff4cebbeaebec5149"), "FirstName" : "David", "LastName" : "Miller" }
{ "_id" : ObjectId("5e418a70f4cebbeaebec514a"), "FirstName" : "John", "LastName" : "Smith", "Age" : 34 }

Sau đây là truy vấn để kiểm tra sự tồn tại và tìm nạp tài liệu không có trường "Tuổi" -

> var iterator = db.demo234.find({"Age":{$exists:false}},{"_id":0});
> iterator.forEach(function(d)
...{
...   printjson(d);
...})

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

{ "FirstName" : "David", "LastName" : "Miller" }