mongoDB之find()


一、find方法

db.collection_name.find();查詢

查詢所有結果

1) db.users.find();類似於select * from users;

 指定返回那些列(鍵)

2) db.users.find({}, {'name' : 1, 'skills' : 1}); 類似於select name, skills from users;

     補充說明: 第一個{} 放where條件 第二個{} 指定那些列顯示和不顯示 (0表示不顯示 1表示顯示)

Where

3)db.users.find({'name' : 'hurry'},{'name' : 1, 'age' : 1, 'skills' : 1});簡單條件,類似於;select name, age, skills from users where name = 'hurry';

使用and

4)  db.users.find({'name' : 'hurry', 'age' : 18},{'name' : 1, 'age' : 1, 'skills' : 1});類似於; select name, age, skills from users where name = 'hurry' and age = 18;

 

使用or

5) db.users.find({ '$or' : [{'name' : 'hurry'}, {'age' : 18}] },{'name' : 1, 'age' : 1, 'skills' : 1});類似於; select name, age, skills from users where name = 'hurry' or age = 18;

 

<, <=, >, >= ($lt, $lte, $gt, $gte )

6) db.users.find({'age' : {'$gte' : 20, '$lte' : 30}});  類似於:select * from users where age >= 20 and age <= 30;

 

使用in, not in ($in, $nin)

7) db.users.find({'age' : {'$in' : [10, 22, 26]}});類似於: select * from users where age in (10, 22, 26);

 

匹配null

8) db.users.find({'age' : null);類似於: select * from users where age is null;

 

like (mongoDB 支持正則表達式)

9)  db.users.find({name:/hurry/});  類似於: select * from users where name like "%hurry%";

10) db.users.find({name:/^hurry/});  類似於: select * from users where name like "hurry%";

 

使用distinct

11) db.users.distinct('name'); 類似於: select distinct (name) from users;

 

使用count

12)dunt();  類似於: select count(*) from users;

 

數組查詢 (mongoDB自己特有的)

  如果skills是 ['java','python']

13)db.users.find({'skills' : 'java'}); 該語句可以匹配成功

  $all

14)db.users.find({'skills' : {'$all' : ['java','python']}}) skills中必須同時包含java 和 python 

  $size:查詢數組的個數符合條件的

15) db.users.find({'skills' : {'$size' : 2}}) 遺憾的是$size不能與$lt等組合使用

  $slice

16)db.users.find({'skills' : {'$slice : [1,1]}}):兩個參數分別是偏移量和返回的數量

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM