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

Làm cách nào để đếm số lần lặp lại của con trỏ trong MongoDB?

Bạn cần sử dụng logic tùy chỉnh với sự trợ giúp của vòng lặp while cùng với con trỏ find (). Hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -

> db.demo724.insertOne(
...    {
...       details:
...       {
...          id:101,
...          otherDetails:[
...             {Name:"Chris"}
...          ]
...       }
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5eab0cce43417811278f5890")
}
>
>
> db.demo724.insertOne(
... {
...
... }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5eab0cce43417811278f5891")
}
> db.demo724.insertOne(
...    {
...       details:
...       {
...          id:1001
...       }
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5eab0cce43417811278f5892")
}

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

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

{ "_id" : ObjectId("5eab0cce43417811278f5890"), "details" : { "id" : 101, "otherDetails" : [ { "Name" : "Chris" } ] } }
{ "_id" : ObjectId("5eab0cce43417811278f5891") }
{ "_id" : ObjectId("5eab0cce43417811278f5892"), "details" : { "id" : 1001 } }

Sau đây là truy vấn để đếm số lần lặp lại của con trỏ trong MongoDB -

> var c=db.demo724.find();
> var detailsCount=0;
> while (c.hasNext()) {
...    var current = c.next();
...    if (typeof current["details"] != "undefined") {
...       detailsCount++;
...    }
... }
1
> print("number of details: " + detailsCount);

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

number of details: 2