當指定的值在陣列中時,將布林欄位 true 新增到返回的物件中。對於 NULL 或其他值,則設定為 false。


為此,請使用 $ifNull。它計算一個表示式,如果表示式計算為非 NULL 值,則返回表示式的值。我們首先建立一個包含文件的集合 -

> db.demo542.insertOne({"ListOfName":["Chris","David"]});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8cabc6ef4dcbee04fbbc17")
}
> db.demo542.insertOne({"ListOfName":null});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8cabc8ef4dcbee04fbbc18")
}
> db.demo542.insertOne({"ListOfName":["David"]});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8cabd3ef4dcbee04fbbc19")
}
> db.demo542.insertOne({"Name":"John"});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8cabdaef4dcbee04fbbc1a")
}

使用 find() 方法顯示集合中的所有文件 -

> db.demo542.find();

這將產生以下輸出 -

{ "_id" : ObjectId("5e8cabc6ef4dcbee04fbbc17"), "ListOfName" : [ "Chris", "David" ] }
{ "_id" : ObjectId("5e8cabc8ef4dcbee04fbbc18"), "ListOfName" : null }
{ "_id" : ObjectId("5e8cabd3ef4dcbee04fbbc19"), "ListOfName" : [ "David" ] }
{ "_id" : ObjectId("5e8cabdaef4dcbee04fbbc1a"), "Name" : "John" }

以下是檢查特定值的查詢 -

> var id = "David";
> db.demo542.aggregate([
...    {
...       "$project": {
...          "matched": {
...             "$eq": [
...                {
...                   "$size": {
...                      "$ifNull": [
...                         { "$setIntersection": [ "$ListOfName", [id] ] },
...                         []
...                      ]
...                   }
...                },
...                1
...             ]
...          }
...       }
...    }
... ])

這將產生以下輸出 -

{ "_id" : ObjectId("5e8cabc6ef4dcbee04fbbc17"), "matched" : true }
{ "_id" : ObjectId("5e8cabc8ef4dcbee04fbbc18"), "matched" : false }
{ "_id" : ObjectId("5e8cabd3ef4dcbee04fbbc19"), "matched" : true }
{ "_id" : ObjectId("5e8cabdaef4dcbee04fbbc1a"), "matched" : false }

更新於: 14-5-2020

199 次瀏覽

開啟你的 職業生涯

完成課程並獲得認證

開始
廣告
© . All rights reserved.