在 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
}
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP