在 MongoDB 能否透過屬性名稱搜尋帶有該屬性的任何文件?


為此,你可以使用 $ne 運算子。我們首先建立一個包含文件的集合 -

> db.searchByPropertyName.insertOne({"FirstName":"Larry","Age":23});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cbaf7af7219729fde21ddb5")
}
> db.searchByPropertyName.insertOne({"FirstName":null,"Age":21});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cbaf7b97219729fde21ddb6")
}
> db.searchByPropertyName.insertOne({"FirstName":"John","Age":22});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cbaf7c57219729fde21ddb7")
}
> db.searchByPropertyName.insertOne({"FirstName":null,"Age":25});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cbaf7d07219729fde21ddb8")
}
> db.searchByPropertyName.insertOne({"FirstName":"David","Age":20});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cbaf7df7219729fde21ddb9")
}

下面是使用 find() prettyprint 顯示集合中所有文件的查詢 -

> db.searchByPropertyName.find().pretty();

這將產生以下輸出 -

{
   "_id" : ObjectId("5cbaf7af7219729fde21ddb5"),
   "FirstName" : "Larry",
   "Age" : 23
}
{
   "_id" : ObjectId("5cbaf7b97219729fde21ddb6"),
   "FirstName" : null,
   "Age" : 21
}
{
   "_id" : ObjectId("5cbaf7c57219729fde21ddb7"),
   "FirstName" : "John",
   "Age" : 22
}
{
   "_id" : ObjectId("5cbaf7d07219729fde21ddb8"),
   "FirstName" : null,
   "Age" : 25
}
{
   "_id" : ObjectId("5cbaf7df7219729fde21ddb9"),
   "FirstName" : "David",
   "Age" : 20
}

下面是透過屬性名稱搜尋帶有該屬性的任何文件的查詢 -

> db.searchByPropertyName.find({FirstName: { $ne : null } } ).pretty();

這將產生以下輸出 -

{
   "_id" : ObjectId("5cbaf7af7219729fde21ddb5"),
   "FirstName" : "Larry",
   "Age" : 23
}
{
   "_id" : ObjectId("5cbaf7c57219729fde21ddb7"),
   "FirstName" : "John",
   "Age" : 22
}
{
   "_id" : ObjectId("5cbaf7df7219729fde21ddb9"),
   "FirstName" : "David",
   "Age" : 20
}

更新於:30-7-2019

197 次瀏覽

開啟你的職業生涯

完成課程後獲得認證

開始
廣告
© . All rights reserved.