條件操作符用于比較兩個(gè)表達(dá)式并從mongoDB集合中獲取數(shù)據(jù)。
在本章節(jié)中,我們將討論如何在MongoDB中使用條件操作符。
MongoDB中條件操作符有:
我們使用的數(shù)據(jù)庫名稱為"w3cschooldb" 我們的集合名稱為"col",以下為我們插入的數(shù)據(jù)。
為了方便測(cè)試,我們可以先使用以下命令清空集合 "col" 的數(shù)據(jù):
db.col.remove({})
插入以下數(shù)據(jù)
>db.col.insert({
title: 'PHP 教程',
description: 'PHP 是一種創(chuàng)建動(dòng)態(tài)交互性站點(diǎn)的強(qiáng)有力的服務(wù)器端腳本語言。',
by: 'w3cschool',
url: 'http://hgci.cn',
tags: ['php'],
likes: 200
})
>db.col.insert({title: 'Java 教程',
description: 'Java 是由Sun Microsystems公司于1995年5月推出的高級(jí)程序設(shè)計(jì)語言。',
by: 'w3cschool',
url: 'http://hgci.cn',
tags: ['java'],
likes: 150
})
>db.col.insert({title: 'MongoDB 教程',
description: 'MongoDB 是一個(gè) Nosql 數(shù)據(jù)庫',
by: 'w3cschool',
url: 'http://hgci.cn',
tags: ['mongodb'],
likes: 100
})
使用?find()
?命令查看數(shù)據(jù):
> db.col.find()
{ "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一種創(chuàng)建動(dòng)態(tài)交互性站點(diǎn)的強(qiáng)有力的服務(wù)器端腳本語言。", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高級(jí)程序設(shè)計(jì)語言。", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "java" ], "likes" : 150 }
{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個(gè) Nosql 數(shù)據(jù)庫", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "mongodb" ], "likes" : 100 }
如果你想獲取 "col" 集合中 "likes" 大于 100 的數(shù)據(jù),你可以使用以下命令:
db.col.find({"likes" : {$gt : 100}})
類似于SQL語句:
Select * from col where likes > 100;
輸出結(jié)果:
> db.col.find({"likes" : {$gt : 100}})
{ "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一種創(chuàng)建動(dòng)態(tài)交互性站點(diǎn)的強(qiáng)有力的服務(wù)器端腳本語言。", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高級(jí)程序設(shè)計(jì)語言。", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "java" ], "likes" : 150 }
>
如果你想獲取"col"集合中 "likes" 大于等于 100 的數(shù)據(jù),你可以使用以下命令:
db.col.find({likes : {$gte : 100}})
類似于SQL語句:
Select * from col where likes >=100;
輸出結(jié)果:
> db.col.find({likes : {$gte : 100}})
{ "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一種創(chuàng)建動(dòng)態(tài)交互性站點(diǎn)的強(qiáng)有力的服務(wù)器端腳本語言。", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高級(jí)程序設(shè)計(jì)語言。", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "java" ], "likes" : 150 }
{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個(gè) Nosql 數(shù)據(jù)庫", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "mongodb" ], "likes" : 100 }
>
如果你想獲取"col"集合中 "likes" 小于 150 的數(shù)據(jù),你可以使用以下命令:
db.col.find({likes : {$lt : 150}})
類似于SQL語句:
Select * from col where likes < 150;
輸出結(jié)果:
> db.col.find({likes : {$lt : 150}})
{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個(gè) Nosql 數(shù)據(jù)庫", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "mongodb" ], "likes" : 100 }
如果你想獲取"col"集合中 "likes" 小于等于 150 的數(shù)據(jù),你可以使用以下命令:
db.col.find({likes : {$lte : 150}})
類似于SQL語句:
Select * from col where likes <= 150;
輸出結(jié)果:
> db.col.find({likes : {$lte : 150}})
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高級(jí)程序設(shè)計(jì)語言。", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "java" ], "likes" : 150 }
{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個(gè) Nosql 數(shù)據(jù)庫", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "mongodb" ], "likes" : 100 }
如果你想獲取"col"集合中 "likes" 大于100,小于 200 的數(shù)據(jù),你可以使用以下命令:
db.col.find({likes : {$lt :200, $gt : 100}})
類似于SQL語句:
Select * from col where likes>100 AND likes<200;
輸出結(jié)果:
> db.col.find({likes : {$lt :200, $gt : 100}})
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高級(jí)程序設(shè)計(jì)語言。", "by" : "w3cschool", "url" : "http://hgci.cn", "tags" : [ "java" ], "likes" : 150 }
>
更多建議: