使用MongoDB查询返回所有整数的年龄记录

要从具有字符串和int ages记录的记录中获取所有int的年龄,请使用$type。MongoDB $type中的$type选择文档,其中字段的值是指定BSON类型的实例。

让我们创建一个包含文档的集合-

> db.demo470.insertOne({"Age":23});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e805456b0f3fa88e2279070")
}
> db.demo470.insertOne({"Age":"Unknown"});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e80545cb0f3fa88e2279071")
}
> db.demo470.insertOne({"Age":24});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e805461b0f3fa88e2279072")
}
> db.demo470.insertOne({"Age":"Not provided"});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e80546bb0f3fa88e2279073")
}

find()方法的帮助下显示集合中的所有文档-

> db.demo470.find();

这将产生以下输出-

{ "_id" : ObjectId("5e805456b0f3fa88e2279070"), "Age" : 23 }
{ "_id" : ObjectId("5e80545cb0f3fa88e2279071"), "Age" : "Unknown" }
{ "_id" : ObjectId("5e805461b0f3fa88e2279072"), "Age" : 24 }
{ "_id" : ObjectId("5e80546bb0f3fa88e2279073"), "Age" : "Not provided" }

以下是查询以返回所有为整数的年龄-

> db.demo470.find( {'Age' : { $type :"number"} } );

这将产生以下输出-

{ "_id" : ObjectId("5e805456b0f3fa88e2279070"), "Age" : 23 }
{ "_id" : ObjectId("5e805461b0f3fa88e2279072"), "Age" : 24 }