MongoDB 條件操作符
描述
條件操作符用於比較兩個表達式並從mongoDB集合中獲取數據。
在本章節中,我們將討論如何在MongoDB中使用條件操作符。
MongoDB中條件操作符有:
- (>) 大於 - $gt
- (<) 小於 - $lt
- (>=) 大於等於 - $gte
- (<= ) 小於等於 - $lte
我們使用的數據庫名稱為"runoob" 我們的集合名稱為"col",以下為我們插入的數據。
為了方便測試,我們可以先使用以下命令清空集合 "col" 的數據:
db.col.remove({})
插入以下數據
>db.col.insert({ title: 'PHP 教程', description: 'PHP 是一種創建動態交互性站點的強有力的服務器端腳本語言。', by: '菜鳥教程', url: 'http://rb.wikimirror.xyz', tags: ['php'], likes: 200 })
>db.col.insert({title: 'Java 教程', description: 'Java 是由Sun Microsystems公司於1995年5月推出的高級程序設計語言。', by: '菜鳥教程', url: 'http://rb.wikimirror.xyz', tags: ['java'], likes: 150 })
>db.col.insert({title: 'MongoDB 教程', description: 'MongoDB 是一個 Nosql 數據庫', by: '菜鳥教程', url: 'http://rb.wikimirror.xyz', tags: ['mongodb'], likes: 100 })
使用find()命令查看數據:
> db.col.find() { "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一種創建動態交互性站點的強有力的服務器端腳本語言。", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "php" ], "likes" : 200 } { "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司於1995年5月推出的高級程序設計語言。", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "java" ], "likes" : 150 } { "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個 Nosql 數據庫", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "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}}) { "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一種創建動態交互性站點的強有力的服務器端腳本語言。", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "php" ], "likes" : 200 } { "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司於1995年5月推出的高級程序設計語言。", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "java" ], "likes" : 150 } >
MongoDB(>=)大於等於操作符 - $gte
如果你想獲取"col"集合中 "likes" 大於等於 100 的數據,你可以使用以下命令:
db.col.find({likes : {$gte : 100}})
類似於SQL語句:
Select * from col where likes >=100;
輸出結果:
> db.col.find({likes : {$gte : 100}}) { "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一種創建動態交互性站點的強有力的服務器端腳本語言。", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "php" ], "likes" : 200 } { "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司於1995年5月推出的高級程序設計語言。", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "java" ], "likes" : 150 } { "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個 Nosql 數據庫", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "mongodb" ], "likes" : 100 } >
MongoDB (<) 小於操作符 - $lt
如果你想獲取"col"集合中 "likes" 小於 150 的數據,你可以使用以下命令:
db.col.find({likes : {$lt : 150}})
類似於SQL語句:
Select * from col where likes < 150;
輸出結果:
> db.col.find({likes : {$lt : 150}}) { "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個 Nosql 數據庫", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "mongodb" ], "likes" : 100 }
MongoDB (<=) 小於等於操作符 - $lte
如果你想獲取"col"集合中 "likes" 小於等於 150 的數據,你可以使用以下命令:
db.col.find({likes : {$lte : 150}})
類似於SQL語句:
Select * from col where likes <= 150;
輸出結果:
> db.col.find({likes : {$lte : 150}}) { "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司於1995年5月推出的高級程序設計語言。", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "java" ], "likes" : 150 } { "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個 Nosql 數據庫", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "mongodb" ], "likes" : 100 }
MongoDB 使用 (<) 和 (>) 查詢 - $lt 和 $gt
如果你想獲取"col"集合中 "likes" 大於100,小於 200 的數據,你可以使用以下命令:
db.col.find({likes : {$lt :200, $gt : 100}})
類似於SQL語句:
Select * from col where likes>100 AND likes<200;
輸出結果:
> db.col.find({likes : {$lt :200, $gt : 100}}) { "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司於1995年5月推出的高級程序設計語言。", "by" : "菜鳥教程", "url" : "http://rb.wikimirror.xyz", "tags" : [ "java" ], "likes" : 150 } >
Mrt.L
903***165@qq.com
一些簡寫說明:
Mrt.L
903***165@qq.com
最初的夢想
660***09@qq.com
模糊查詢
查詢 title 包含"教"字的文檔:
查詢 title 字段以"教"字開頭的文檔:
查詢 titl e字段以"教"字結尾的文檔:
最初的夢想
660***09@qq.com
IT_小白鼠
262***7432@qq.com
mongoDb3.2 以上版本新增了位運算進行計算;將數字轉換成二進製後,按位進行位運算:
$bitsAllClear 所有指定為都為 0。
db.user.find({"bitData":{$bitsAllClear:[1,4]}}) 將二進製的第 2 位以及第 5 位上為 0 的匹配出來。
$bitsAllSet 所有指定的都為 1。
db.user.find({"bitData":{$bitsAllSet:[1,4]}}) 將二進製的第 2 位以及第 5 位上為 1 的匹配出來。
$bitsAnyClear 任意一位都為 0 的匹配出來與 $bitsAllClear 一致。
$bitsAnySet 任意一位都為 1 的匹配出來與 $bitsAllSet 一致。
還有一種就是直接通過數字進行位運算 即位語言運算符中的 & 一致。
db.user.find({"bitData":{$bitsAllClear:8}}) 即 bitData 這個列與 8 數字進行 & 位運算結果為 0 的顯示出來。
db.user.find({"bitData":{$bitsAllSet:8}}) 即 bitData 這個列與 8 數字進行 & 位運算結果不為 0 的顯示出來。
通過數字進行計算的話:
IT_小白鼠
262***7432@qq.com