$regexMatch
是MongoDB的聚合运算符,它用于在文档中搜索正则表达式模式。它在MongoDB 3.4及更高版本中可用。
以下是一些使用$regexMatch
的方法:
- 基本使用:
db.collection.aggregate([
{
$match: {
$regexMatch: {
input: "$fieldName", // 需要搜索的字段
regex: "pattern" // 正则表达式
}
}
}
])
- 使用选项:
db.collection.aggregate([
{
$match: {
$regexMatch: {
input: "$fieldName", // 需要搜索的字段
regex: "pattern", // 正则表达式
options: "i" // 正则表达式选项
}
}
}
])
- 使用
$regexMatch
在数组中搜索:
db.collection.aggregate([
{
$match: {
$regexMatch: {
input: "$arrayFieldName", // 数组字段
regex: "pattern", // 正则表达式
options: "i", // 正则表达式选项
// 指定在数组中搜索所有元素
// 如果不指定,则默认搜索第一个元素
// 如果指定`analyzeWildcard: true`, 则可以使用'.*'作为通配符匹配任意元素
// 如果指定`maxPatternLength`,则可以限制匹配的最大长度
// 如果指定`capture`,则可以捕获正则表达式的部分匹配
// 如果指定`language`,则可以指定本地化的正则表达式匹配
// 如果指定`caseSensitive`,则可以指定是否区分大小写
// 如果指定`diacriticSensitive`,则可以指定是否区分重音
}
}
}
])
注意:在使用$regexMatch
时,你需要确保你的MongoDB版本至少是3.4,因为$regexMatch
是在这个版本中引入的。如果你的版本低于3.4,你将无法使用$regexMatch
。