MongoDB多條件模糊查詢示例代碼
前言
模糊查詢是數(shù)據(jù)庫的基本操作之一,實現(xiàn)對給定的字符串是否與指定的模式進行匹配。如果字符完全匹配,可以用=等號表示,如果部分匹配可認為是一種模糊查詢。在關(guān)系型數(shù)據(jù)中,通過SQL使用like ‘%fens%'的語法。那么在mongodb中我們應(yīng)該如何實現(xiàn)模糊查詢的效果呢。
查詢條件
| 關(guān)鍵字 | 說明 |
|---|---|
| $or | 或關(guān)系 |
| $nor | 或關(guān)系取反 |
| $gt | 大于 |
| $gte | 大于等于 |
| $lt | 小于 |
| $lte | 小于等于 |
| $ne | 不等于 |
| $in | 在多個值范圍內(nèi) |
| $nin | 不在多個值范圍內(nèi) |
| $all | 匹配數(shù)組中多個值 |
| $regex | 正則,用于模糊查詢 |
| $size | 匹配數(shù)組大小 |
| $maxDistance | 范圍查詢,距離(基于LBS) |
| $mod | 取模運算 |
| $near | 鄰域查詢,查詢附近的位置(基于LBS) |
| $exists | 字段是否存在 |
| $elemMatch | 匹配內(nèi)數(shù)組內(nèi)的元素 |
| $within | 范圍查詢(基于LBS) |
| $box | 范圍查詢,矩形范圍 |
| $center | 范圍查詢,圓形范圍 |
| $centerSphere | 范圍查詢,球形范圍 |
| $slice | 查詢字段集合中的元素(比如從第幾個之后,第N到第M個元素) |
模糊查詢
精準查詢
//Mongodb數(shù)據(jù)庫表
const systemUser = require('../../models/user');
systemUser.find({name:'xiaoming'}).exec(function(err,rs){}
多條件模糊查詢
//Mongodb數(shù)據(jù)庫表
const systemUser = require('../../models/user');
//前端傳入的要查詢的關(guān)鍵字
var name = req.query.name;
var page = req.query.page || 1; //當(dāng)前頁數(shù)
var limitNums = 10; //指定每一頁查詢的條數(shù)
page = parseInt(page);
var skipNums = (page - 1) * limitNums; //跳過指定數(shù)量
//正則匹配 i忽略大小寫
var reg = new RegExp(name, "i");
var _filter = {
//多字段匹配
$or: [
{name: {$regex: reg}},
{description: {$regex: reg}},
{owner: {$regex: reg}},
]
}
systemUser.find(_filter).
//跳過指定數(shù)量的數(shù)據(jù)
skip(skipNums).
//指定從MongoDB中讀取的記錄條數(shù)。
limit(limitNums).
sort({createTime:-1}).
exec(function(err,rs){}
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
CentOS7下安裝MongoDB數(shù)據(jù)庫過程
大家好,本篇文章主要講的是CentOS7下安裝MongoDB數(shù)據(jù)庫過程,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12
MongoDB學(xué)習(xí)之Text Search文本搜索功能
這篇文章主要給大家介紹了MongoDB之Text Search文本搜索功能的相關(guān)資料,文中給出了詳細的示例代碼供大家參考學(xué)習(xí),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-05-05
Mongoose find 查詢返回json數(shù)據(jù)處理方式
這篇文章主要介紹了Mongoose find 查詢返回json數(shù)據(jù)處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04

