如果另一個欄位為空值,而第一個欄位不為空值,則 MongoDB 查詢如何選擇一個欄位?
為此,需使用 $ifNull 運算子
讓我們首先使用文件建立一個集合 −
> dbquerySelectDemoinsertOne({"Value1":10,"Value2":null});
{
"acknowledged" : true,
"insertedId" : ObjectId("5cefc0ceef71edecf6a1f6b6")
}
> dbquerySelectDemoinsertOne({"Value1":null,"Value2":30});
{
"acknowledged" : true,
"insertedId" : ObjectId("5cefc0d7ef71edecf6a1f6b7")
}
> dbquerySelectDemoinsertOne({"Value1":60,"Value2":40});
{
"acknowledged" : true,
"insertedId" : ObjectId("5cefc0e2ef71edecf6a1f6b8")
}在集合中使用 find() 方法顯示所有文件 −
> dbquerySelectDemofind()pretty();
輸出
{
"_id" : ObjectId("5cefc0ceef71edecf6a1f6b6"),
"Value1" : 10,
"Value2" : null
}
{
"_id" : ObjectId("5cefc0d7ef71edecf6a1f6b7"),
"Value1" : null,
"Value2" : 30
}
{
"_id" : ObjectId("5cefc0e2ef71edecf6a1f6b8"),
"Value1" : 60,
"Value2" : 40
}以下是如果其他欄位為空值,則選擇一個欄位的查詢 −
> dbquerySelectDemoaggregate([
{
$project: {
"Value1": { "$ifNull": [ "$Value1", "$Value2" ] }
}
}
]);輸出
{ "_id" : ObjectId("5cefc0ceef71edecf6a1f6b6"), "Value1" : 10 }
{ "_id" : ObjectId("5cefc0d7ef71edecf6a1f6b7"), "Value1" : 30 }
{ "_id" : ObjectId("5cefc0e2ef71edecf6a1f6b8"), "Value1" : 60 }
廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP