在 MongoDB 中基于 true 或 false 值进行查询


要基于 true 或 false 值进行查找,请在 find() 中使用 $exists。您还需要点表示法来完成同样的任务。

首先,让我们使用文档创建一个集合 -

> db.demo367.insertOne(
...    { "Id" : "102",
...    "details" : [ { "Name" : "David"},
...    { "Age" : 23, "CountryName" : "UK"} ],
...    "isMarried" : false }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e57e0b62ae06a1609a00ae8")
}
> db.demo367.insertOne(
...    { "Id" : "101",
...    "details" : [ { "Name" : "Chris", "Subject" : [ "MySQL" ] },
...    { "Age" : 21, "CountryName" : "US"} ],
...    "isMarried" : true }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e57e0be2ae06a1609a00ae9")
}

在集合中显示所有文档,并使用 find() 方法 -

> db.demo367.find();

这会产生以下输出 -

{
   "_id" : ObjectId("5e57e0b62ae06a1609a00ae8"), "Id" : "102", "details" : [
      { "Name" : "David" }, { "Age" : 23, "CountryName" : "UK" } ], "isMarried" : false }
{
   "_id" : ObjectId("5e57e0be2ae06a1609a00ae9"), "Id" : "101", "details" : [
      { "Name" : "Chris", "Subject" : [ "MySQL" ] }, { "Age" : 21, "CountryName" : "US" } ], "isMarried" : true 
}

以下是对照 $exists 进行 true false 值查找的查询 -

> db.demo367.find({"details.Subject": { $exists: false}});

这会产生以下输出 -

{ "_id" : ObjectId("5e57e0b62ae06a1609a00ae8"), "Id" : "102", "details" : [ { "Name" : "David" }, { "Age" : 23, "CountryName" : "UK" } ], "isMarried" : false }

更新日期: 2020 年 4 月 2 日

910 次浏览

启动你的 职业

完成课程,获得认证

开始学习
广告