Atlas Search正则表达式运算符支持使用单词边界(\b)来匹配文本中的单词边界。但是,在Atlas Search中,由于分词器的存在,使用\b可能无法匹配到预期的结果,因为分词器会将文本分成不同的词项。例如,如果要匹配“cat”,但文档中实际上包含“cats”,则使用\b将无法匹配到预期结果。 为了解决这个问题,可以使用$regexMatch和$regexFindAll操作符,同时在正则表达式中添加必要的字符类,以确保只匹配到完整的单词。示例如下:
db.collection.aggregate([ { $search: { index: 'myIndex', compound: { should: [ { $regexMatch: { input: 'search term', regex: '\bterm\b' } }, { $regexFindAll: { input: 'search term with more words', regex: '\bterm\b' } } ] } } } ])