1

我正在尝试使用 Mongoose 将全文搜索模拟到两个字段中。我大部分时间都在测试几种查询类型,但总是失败。MongoDB shell 查询是这样的:

db.feeds.item.find({lang:"en", $or:[{title: /searchexpression/}, {body: /searchexpression/}] })

在此示例中,我只想返回与标题正文字段或两个字段中的搜索表达式(包括正则表达式)匹配的英文文档。此查询有效,但正如我所说,当尝试使用Mongoose调整它时,问题就开始了,:-(

我使用的一些表达方式不起作用:

exports.fullTextSearch = function(lang, text, callback) { 
    MyModel.find({lang:lang, $or: [{title:/text/},{body:/text/}]}).exec(callback);
    MyModel.find({lang:lang, $or: [{title: new RegExp('\/'+text+'\/')}, {body:new RegExp('\/'+text+'\/')}]}).exec(callback);
    MyModel.find({lang:lang}).or({title:/text/},{body:/text/}).exec(callback);
    MyModel.find({lang:lang}).or({title:new RegExp('\/'+text+'\/')},{body:new RegExp('\/'+text+'\/')}).exec(callback);    

}

非常感谢!

路易斯·卡帕。

4

1 回答 1

0

尚未对此进行测试,但根据文档,这应该可以:

MyModel.find({lang:lang}).or([{title:/text/},{body:/text/}]).exec(callback);

像您的第三个示例一样,但在数组中使用“或”条件。

编辑:

要使正则表达式动态化,请使用第四个示例,但在数组中使用“或”条件:

MyModel.find({lang:lang}).or([{title:new RegExp(text)},{body:new RegExp(text)}]).exec(callback);

或者在外面定义正则表达式:

var regexText = new RegExp(text)
MyModel.find({lang:lang}).or([{title:regexText},{body:regexText}]).exec(callback);
于 2012-08-29T08:13:57.170 回答