一、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]}}):兩個參數分別是偏移量和返回的數量