一、比较操作符
用于比较两个表达式并从mongoDB集合中获取数据,常用操作符如下:
操作符 | 格式 | 示例 | 类似于sql语句 | 备注 |
(>)大于 - $gt | {<key>:{$gt:<value>}} | db.big.find({"age":{$gt:22}}) | where age > 22 | 查询age大于22的数据 |
(<)小于 - $lt | {<key>:{$lt:<value>}} | db.big.find({"age":{$lt:20}}) | where age < 20 | |
(>=)大于等于 - $gte | {<key>:{$gte:<value>}} | db.big.find({"age":{$gte:22}}) | where age >= 22 | |
(<=)小于等于 - $lte | {<key>:{$lte:<value>}} | db.big.find({"age":{$lte:22}}) | where age <= 22 | |
(=) 等于 - $eq | {<key>:<value>} | db.big.find({"name":"jun"}) | where name = 'jun' | |
$in | { field: { $in: [<value1>, <value2>, ... <valueN> ] } } |
db.big.find({"age":{$type:"array"}}) db.big.find({"age":{$in:[25,22]}}) |
匹配字段值等于指定数组中的任何值(字段值为数组类型时,数组中至少有一个元素在指定数组中) | |
(!=)不等于 - $ne | {<key>:{$ne:<value>}} | db.big.find({"age":{$ne:22}}) | where age != 22 | |
$nin | { field: { $nin: [ <value1>, <value2> ... <valueN> ]} } |
db.big.find({"name":{$nin:["jun","wang"]}}) db.big.find({"age":{$nin:[25,22]}}) |
字段值不在指定数组或者不存在(字段值为数组类型时,数组中没有一个元素与指定数组中元素相等) |
二、逻辑操作符
操作符 | 格式 | 示例 | 备注 |
$or | { $or: [ { <expression1> }, { <expression2> }, ... , { <expressionN> } ] } | db.big.find({$or:[{"name":"jun"},{"age":25}]}) | 文档至少满足其中的一个表达式 |
$and | { $and: [ { <expression1> }, { <expression2> } , ... , { <expressionN> } ] } | db.big.find({"name":"jun","age":25}) | 文档满足所有的表达式 |
$not | { field: { $not: { <operator-expression> } } } | db.big.find({"age":{$not:{$gt:22}}}) | 字段值不匹配表达式或者字段值不存在 |
$nor | { $nor: [ { <expression1> }, { <expression2> }, ... { <expressionN> } ] } |
db.big.find({$nor:[{"age":18},{"name":"jun"}]}) db.big.find({$nor:[{"name":"jun"},{"age":{$lt:20}},{"sex":"x"}]}) |
字段值不匹配所有的表达式的文档,包括那些不包含这些字段的文档 |
三、元素操作符
3.1 $exists
语法: { field: { $exists: <boolean> } } 1.当boolean为true,$exists匹配包含字段的文档,包括字段值为null的文档。 2.当boolean为false,$exists返回不包含对应字段的文档。 示例: db.big.find({"name":{$exists:true}})
3.2 $type
匹配字段值为指定数据类型的文档
{ field: { $type: <BSON type number> | <String alias> } }
类型 | 数字 | 备注 |
---|---|---|
Double | 1 | |
String | 2 | |
Object | 3 | |
Array | 4 | |
Binary data | 5 | |
Object id | 7 | |
Boolean | 8 | |
Date | 9 | |
Null | 10 | |
Regular Expression | 11 | |
JavaScript | 13 | |
Symbol | 14 | |
JavaScript (with scope) | 15 | |
32-bit integer | 16 | |
Timestamp | 17 | |
64-bit integer | 18 | |
Min key | 255 | Query with -1. |
Max key | 127 |
示例: db.big.find({"name":{$type:2}}) db.big.find({"name":{$type:"string"}})
四、评估操作符
4.1 $mod
匹配字段值被除有指定的余数的文档 语法:{ field: { $mod: [ divisor(除数), remainder(余数) ] } } 示例:db.big.find({"age":{$mod:[5,0]}})
4.2 $regex
语法:
{ <field>: { $regex: /pattern/, $options: '<options>' } } { <field>: { $regex: 'pattern', $options: '<options>' } } { <field>: { $regex: /pattern/<options> } }
参数:
i:忽略大小写
m:多行匹配
x:忽略空格
s:点号可以匹配换行符
示例:
db.big.find({"name":{$regex:/^jun/i}})
db.big.find({"name":{$regex:/^jun/,$options:'i'}})
4.3 $text
MongoDB支持对文本内容执行文本搜索操作,其提供了索引text index和查询操作$text来完成文本搜索功能。
只有拥有text index的collection才支持全文检索
每个collection只能拥有一个text index
Text index可以包含任何的string类型、string数组类型的字段
Text index可以包含多个字段
使用createIndex或ensureIndex函数来创建索引,详见:https://www.cnblogs.com/Xinenhui/p/15871849.html
4.4 $where
$where操作符功能强大且灵活,它可以将JavaScript表达式的字符串或 JavaScript函数作为查询语句的一部分。在JavaScri pt表达式和函数中,可以 使用this或obj来引用当前操作的文档。 JavaScript表达式或函数返回值为true时,才会返回当前的文档。
查询时,$where操作符不能使用索引,每个文档需要从BSON对象转换成 JavaSript对象后,才可以通过$where表达式来运行。因此,它比常规查询要 慢很多,一般情况下,要避免使用$where查询。
五、数组操作符
操作符 | 格式 | 示例 | 备注 |
$all | { <field>: { $all: [ <value1> , <value2> ... ] } } | db.big.find({"name":{$all:["wang","zhang","chen"]}}) | 字段值是包含所有指定元素的数组的文档 |
$elemMatch | { <field>: { $elemMatch: { <query1>, <query2>, ... } } } | db.big.find({"name":{$elemMatch:{"wang":"jun","age":2}}}) | 数组字段至少一个元素满足所有指定查询条件的文档 |
$size | { field: { $size: 2 } } | 匹配数组字段元素个数等于指定数量的文档 |