詳解MongoDB的條件查詢和排序
find 方法
查詢的基本格式是db.collection.find({條件}),其中條件是可選的,類似于 MySQL 的 WHERE 條件一樣。示例如下:
// 查找全部文檔 db.collection.find({}); // 查找指定條件的文檔 db.collection.find({key: value}); // 查找昵稱為島上碼農(nóng)的用戶 db.users.find({nickname: '島上碼農(nóng)'});
條件組合
可以使用 $and、$or 和 $not 來設(shè)置組合條件。
// AND 查詢格式 db.collection.find({ $and: [ {key1: value1}, {key2: value2} ] }); // OR 查詢格式 db.collection.find({ $or: [ {key1: value1}, {key2: value2} ] }); // NOT 查詢格式 db.collection.find( {key: {$not: {條件表達式}} );
例如下面的 users數(shù)據(jù)集:
[ {nickname: '島上碼農(nóng)', score: 90, gender: 'male'}, {nickname: '瑪麗', score: 98, gender: 'female'}, {nickname: 'Tom', score: 76, gender: 'male'} ]
查找分?jǐn)?shù)是90或76分的用戶:
db.users.find({ $or: [ {score: 90}, {score: 76} ] });
查找性別不是 male 的用戶和查找分?jǐn)?shù)高于80分用戶:
db.users.find({ gender: {$not: {$eq: 'male'}} }); db.users.find({ score: {$not: {$lt: 80}} });
其中$eq為相等條件,$lt為小于條件。 條件可以嵌套使用,例如and和and和or 嵌套,表示(a || b) && (c || d),格式如下:
// AND與OR 嵌套查詢格式 db.collection.find({ $and: [ {$or: [{key1: value1}, {key2: value2}]}, {$or: [{key3: value1}, {key4: value2}]}, ] }); //查找 nickename是島上碼農(nóng)或瑪麗,且分?jǐn)?shù)是90或76的用戶 db.users.find({ $and: [ {$or: [{nickname: '島上碼農(nóng)'}, {nickname: '瑪麗'}]}, {$or: [{score: 90}, {score: 76}]} ] }); //查找 nickname是島上碼農(nóng)且分?jǐn)?shù)是90,或nickname是瑪麗且分?jǐn)?shù)是76的用戶 db.users.find({ $or: [ {$and: [{nickname: '島上碼農(nóng)'}, {score: 90}]}, {$and: [{nickname: '瑪麗'}, {score: 76}]} ] }); //查找nickname是島上碼農(nóng),且分?jǐn)?shù)不低于80分的用戶 db.users.find({ $and: [ {nickname: '島上碼農(nóng)'}, {score: {$not:{$lt: 80}}} ] });
比較操作符
在 MongoDB 提供了如下比較操作符,比較操作符的格式為{key: {$op: value}}:
- $eq:相等操作符,即 a == b;
- $gt:大于,即 a > b;
- $gte:大于等于,即 a >= b;
- $lt:小于,即 a < b;
- $lte:小于等于,即 a <= b。
IN 查詢
in 查詢的格式和比較操作符類似,只是對應(yīng)的值是數(shù)組,即
db.collection.find({key: {$in: [...]}});
例如,需要查找分?jǐn)?shù)為90,76的用戶:
db.users.find({score: {$in: [76, 90]}});
in 查詢也可以和其他條件組合,如and 查詢:
db.users.find({ $and: [ {score: {$in: [76, 90]}}, {gender: 'male'} ] });
限制返回結(jié)果條數(shù)和跳過數(shù)據(jù)
find 方法會將所有匹配條件的數(shù)據(jù)查找出來,因此對于數(shù)據(jù)集很大的時候會導(dǎo)致速度很慢且產(chǎn)生大量的 磁盤 I/O,如果確定數(shù)據(jù)只有1條的時候可以使用 findOne,如果要限制查詢條數(shù)可以使用 limit或 skip。limit 是查詢到指定數(shù)量后的結(jié)果就返回,而 skip 是跳過前面指定數(shù)量的結(jié)果。
// 查找指定條件的文檔的 n 條數(shù)據(jù) db.collection.find({key: value}).limit(n); //示例:查詢超過80分的3個用戶 db.users.find({score: {$gt: 80}}).limit(3); // 查找指定條件的文檔的,跳過前 n 條數(shù)據(jù) db.collection.find({key: value}).skip(n); //示例: 查詢超過80分的用戶,跳過前3個 db.users.find({score: {$gt: 80}}).skip(3);
排序
排序使用格式如下:
db.collection.find({條件}).sort({key: 1});
其中1表示升序,-1表示降序,例如我們需要以分?jǐn)?shù)降序排序:
db.users.find().sort({score: -1});
總結(jié)
本篇介紹了 MongoDB 的條件查詢操作,限制返回條數(shù)和排序。可以看到,MongoDB 的操作雖然語法和 SQL 不同,但是都有對應(yīng)的功能輔助查詢,對于查詢來說也是十分便捷的。
以上就是詳解MongoDB的條件查詢和排序的詳細(xì)內(nèi)容,更多關(guān)于MongoDB的條件查詢和排序的資料請關(guān)注本站其它相關(guān)文章!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。