1
我試圖用Mongoose emilation與全文搜索到兩個領域。我花了大部分時間來測試幾種查詢類型,但我總是失敗。該MongoDB的外殼查詢是這個:貓鼬:布爾'或'用通配符查詢
db.feeds.item.find({lang:"en", $or:[{title: /searchexpression/}, {body: /searchexpression/}] })
在這個例子中,我想回到在標題或體字段或在這兩個領域相匹配的搜索表達式(包括正則表達式)只有英文文件。此查詢工作,但問題開始,正如我所說的,試圖用貓鼬適應它的時候,:-(
,我曾經和一些表達式沒」 T工作:
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);
}
非常感謝你!
路易斯·卡帕。
我以前試過相同的查詢,並沒有工作。我再次複製粘貼到你的建議和什麼都沒有,:-(我開始認爲這可能是一個貓鼬的bug ... – lcappa
我試過包括RegExp的查詢,沒有運氣 – lcappa
我簡化了查詢執行搜索到只有一個字段,如:MyModel.find({lang:lang,title:new RegExp('\ /'+ text +'\ /')})。exec(callback);它可能是一個與Mongoose相關的錯誤使用正則表達式,甚至是一個非文檔化的查詢組件 – lcappa