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

Làm cách nào để lấy chỉ mục của một phần tử mảng trong các phiên bản cũ hơn trên MongoDB?

Để lấy chỉ mục của một phần tử mảng, hãy sử dụng $ indexOfArray. Hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -

> db.demo65.insertOne({"ListOfValues":[10,20,30]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e28990ecfb11e5c34d89938")
}
> db.demo65.insertOne({"ListOfValues":[50,60,70,100]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e28991ecfb11e5c34d89939")
}
> db.demo65.insertOne({"ListOfValues":[30,40,89,91,98]});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e28992bcfb11e5c34d8993a")
}

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

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

{ "_id" : ObjectId("5e28990ecfb11e5c34d89938"), "ListOfValues" : [ 10, 20, 30 ] }
{ "_id" : ObjectId("5e28991ecfb11e5c34d89939"), "ListOfValues" : [ 50, 60, 70, 100 ] }
{ "_id" : ObjectId("5e28992bcfb11e5c34d8993a"), "ListOfValues" : [ 30, 40, 89, 91, 98 ] }

Đây là truy vấn để lấy chỉ mục của một phần tử mảng trong các phiên bản cũ hơn trên MongoDB -

> db.demo65.aggregate(
...    [
...       {
...          $project:
...          {
...             IndexOfAnArrayElement: { $indexOfArray: [ "$ListOfValues", 30] },
...          }
...       }
...    ]
... );

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

{ "_id" : ObjectId("5e28990ecfb11e5c34d89938"), "IndexOfAnArrayElement" : 2 }
{ "_id" : ObjectId("5e28991ecfb11e5c34d89939"), "IndexOfAnArrayElement" : -1 }
{ "_id" : ObjectId("5e28992bcfb11e5c34d8993a"), "IndexOfAnArrayElement" : 0 }