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