1. 程式人生 > >MongoDB學習筆記(7)--- 條件操作符

MongoDB學習筆記(7)--- 條件操作符

描述

條件操作符用於比較兩個表示式並從mongoDB集合中獲取資料。

在本章節中,我們將討論如何在MongoDB中使用條件操作符。

MongoDB中條件操作符有:

  • (>) 大於 - $gt
  • (<) 小於 - $lt
  • (>=) 大於等於 - $gte
  • (<= ) 小於等於 - $lte

我們使用的資料庫名稱為"runoob" 我們的集合名稱為"col",以下為我們插入的資料。

為了方便測試,我們可以先使用以下命令清空集合 "col" 的資料:

db.col.remove({})

插入以下資料

>db.col.insert({ title: 'PHP 教程', description: 'PHP 是一種建立動態互動性站點的強有力的伺服器端指令碼語言。', by: '菜鳥教程', url: 'http://www.runoob.com', tags: ['php'], likes: 200 })

>db.col.insert({title: 'Java 教程', description: 'Java 是由Sun Microsystems公司於1995年5月推出的高階程式設計語言。', by: '菜鳥教程', url: 'http://www.runoob.com', tags: ['java'], likes: 150 })

>db.col.insert({title: 'MongoDB 教程', description: 'MongoDB 是一個 Nosql 資料庫', by: '菜鳥教程', url: 'http://www.runoob.com', tags: ['mongodb'], likes: 100 })

使用find()命令檢視資料:

> db.col.find() { "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一種建立動態互動性站點的強有力的伺服器端指令碼語言。", "by" : "菜鳥教程", "url" : "http://www.runoob.com", "tags" : [ "php" ], "likes" : 200 } { "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司於1995年5月推出的高階程式設計語言。", "by" : "菜鳥教程", "url" : "http://www.runoob.com", "tags" : [ "java" ], "likes" : 150 } { "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個 Nosql 資料庫", "by" : "菜鳥教程", "url" : "http://www.runoob.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}}) { "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一種建立動態互動性站點的強有力的伺服器端指令碼語言。", "by" : "菜鳥教程", "url" : "http://www.runoob.com", "tags" : [ "php" ], "likes" : 200 } { "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司於1995年5月推出的高階程式設計語言。", "by" : "菜鳥教程", "url" : "http://www.runoob.com", "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://www.runoob.com", "tags" : [ "php" ], "likes" : 200 } { "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司於1995年5月推出的高階程式設計語言。", "by" : "菜鳥教程", "url" : "http://www.runoob.com", "tags" : [ "java" ], "likes" : 150 } { "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個 Nosql 資料庫", "by" : "菜鳥教程", "url" : "http://www.runoob.com", "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://www.runoob.com", "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://www.runoob.com", "tags" : [ "java" ], "likes" : 150 } { "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個 Nosql 資料庫", "by" : "菜鳥教程", "url" : "http://www.runoob.com", "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://www.runoob.com", "tags" : [ "java" ], "likes" : 150 } >
     
  1. 一些簡寫說明:

    $gt -------- greater than  >
    
    $gte --------- gt equal >= $lt -------- less than < $lte --------- lt equal <= $ne ----------- not equal != $eq -------- equal =
     
  2. 模糊查詢

    查詢 title 包含"教"字的文件:

    db.col.find({title:/教/})

    查詢 title 欄位以"教"字開頭的文件:

    db.col.find({title:/^教/})

    查詢 titl e欄位以"教"字結尾的文件:

    db.col.find({title:/教$/})