描述
条件操作符用于比较两个表达式并从mongoDB集合中获取数据。
在本章节中,我们将讨论如何在MongoDB中使用条件操作符。
MongoDB中条件操作符有:
- (>) 大于 - $gt
- (<) 小于 - $lt
- (>=) 大于等于 - $gte
- (<= ) 小于等于 - $lte
我们使用的数据库名称为"runoops" 我们的集合名称为"col",以下为我们插入的数据。
为了方便测试,我们可以先使用以下命令清空集合 "col" 的数据:
> use runoops;
switched to db runoops
db.col.remove({})
插入以下数据
> db.col.insert({
... title: 'PHP 教程',
... description: 'PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。',
... by: 'runoops自学教程',
... url: 'http://www.runoops.com',
... tags: ['php'],
... likes: 300
... })
WriteResult({ "nInserted" : 1 })
>
> db.col.insert({title: 'Java 教程',
... description: 'Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。',
... by: 'runoops自学教程',
... url: 'http://www.runoops.com',
... tags: ['java'],
... likes: 250
... })
WriteResult({ "nInserted" : 1 })
> db.col.insert({title: 'MongoDB 教程',
... description: 'MongoDB 是一个 Nosql 数据库',
... by: 'runoops自学教程',
... url: 'http://www.runoops.com',
... tags: ['mongodb'],
... likes: 100
... })
WriteResult({ "nInserted" : 1 })
使用find()命令查看数据:
> db.col.find().pretty()
{
"_id" : ObjectId("62c03e288c761b9926dce925"),
"title" : "PHP 教程",
"description" : "PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。",
"by" : "runoops自学教程",
"url" : "http://www.runoops.com",
"tags" : [
"php"
],
"likes" : 300
}
{
"_id" : ObjectId("62c03eb58c761b9926dce927"),
"title" : "Java 教程",
"description" : "Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。",
"by" : "runoops自学教程",
"url" : "http://www.runoops.com",
"tags" : [
"java"
],
"likes" : 250
}
{
"_id" : ObjectId("62c03ebc8c761b9926dce928"),
"title" : "MongoDB 教程",
"description" : "MongoDB 是一个 Nosql 数据库",
"by" : "runoops自学教程",
"url" : "http://www.runoops.com",
"tags" : [
"mongodb"
],
"likes" : 100
}
>
MongoDB (>) 大于操作符 - $gt
如果你想获取 "col" 集合中 "likes" 大于 100 的数据,你可以使用以下命令:
db.col.find({likes : {$gt : 100}})
类似于SQL语句:
Select * from col where likes > 100;
输出结果:
> db.col.find({likes : {$gt : 100}}).pretty()
{
"_id" : ObjectId("62c03e288c761b9926dce925"),
"title" : "PHP 教程",
"description" : "PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。",
"by" : "runoops自学教程",
"url" : "http://www.runoops.com",
"tags" : [
"php"
],
"likes" : 300
}
{
"_id" : ObjectId("62c03eb58c761b9926dce927"),
"title" : "Java 教程",
"description" : "Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。",
"by" : "runoops自学教程",
"url" : "http://www.runoops.com",
"tags" : [
"java"
],
"likes" : 250
}
>
MongoDB (<) 小于操作符 - $lt
如果你想获取"col"集合中 "likes" 小于 150 的数据,你可以使用以下命令:
db.col.find({likes : {$lt : 150}})
类似于SQL语句:
Select * from col where likes < 150;
输出结果:
> db.col.find({likes : {$lt : 150}}).pretty()
{
"_id" : ObjectId("62c03ebc8c761b9926dce928"),
"title" : "MongoDB 教程",
"description" : "MongoDB 是一个 Nosql 数据库",
"by" : "runoops自学教程",
"url" : "http://www.runoops.com",
"tags" : [
"mongodb"
],
"likes" : 100
}
>
MongoDB (<=) 小于等于操作符 - $lte
如果你想获取"col"集合中 "likes" 小于等于 250 的数据,你可以使用以下命令:
db.col.find({likes : {$lte : 250}})
类似于SQL语句:
Select * from col where likes <= 250;
输出结果:
> db.col.find({likes : {$lte : 250}}).pretty()
{
"_id" : ObjectId("62c03eb58c761b9926dce927"),
"title" : "Java 教程",
"description" : "Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。",
"by" : "runoops自学教程",
"url" : "http://www.runoops.com",
"tags" : [
"java"
],
"likes" : 250
}
{
"_id" : ObjectId("62c03ebc8c761b9926dce928"),
"title" : "MongoDB 教程",
"description" : "MongoDB 是一个 Nosql 数据库",
"by" : "runoops自学教程",
"url" : "http://www.runoops.com",
"tags" : [
"mongodb"
],
"likes" : 100
}
>
MongoDB 使用 (<) 和 (>) 查询 - $lt 和 $gt
如果你想获取"col"集合中 "likes" 大于100,小于 300 的数据,你可以使用以下命令:
db.col.find({likes : {$lt :300, $gt : 100}})
类似于SQL语句:
Select * from col where likes>100 AND likes<300;
输出结果:
> db.col.find({likes : {$lt :300, $gt : 100}}).pretty()
{
"_id" : ObjectId("62c03eb58c761b9926dce927"),
"title" : "Java 教程",
"description" : "Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。",
"by" : "runoops自学教程",
"url" : "http://www.runoops.com",
"tags" : [
"java"
],
"likes" : 250
}
>