我试图根据用户搜索的内容生成查询。我有一个字符串数组,我只想在mongoDB选择器中发送,我的问题是使用/ text / syntax,它可以在mongoDB控制台中完美地运行,如下所示:
Items.find({ $or: [{name: /doc/}, {tags: /doc/}, {name: /test/}, {tags: /test/}] });
但是我无法在javascript中编写相同的语法,我已经尝试了几个版本。
var mongoDbArr = [];
searchArray.forEach(function(text) {
mongoDbArr.push({name: /text/});
mongoDbArr.push({tags: /text/});
});
return Items.find({ $or: mongoDbArr});
但它只搜索“文本”而不是变量中的什么。像这样:
var mongoDbArr = [];
searchArray.forEach(function(text) {
mongoDbArr.push({name: "/" + text + "/"});
mongoDbArr.push({tags: "/" + text + "/"});
});
return Items.find({ $or: mongoDbArr});
但这并没有给我任何结果。我错过了什么?
答案 0 :(得分:18)
您必须使用javascript:
构建正则表达式var mongoDbArr = [];
searchArray.forEach(function(text) {
mongoDbArr.push({name: new RegExp(text)});
mongoDbArr.push({tags: new RegExp(text,"i")});
});
return Items.find({ $or: mongoDbArr});
或者使用mongodb的regular expressions查询:
mongoDbArr.push({name: { $regex : text, $options:"i" } });
mongoDbArr.push({tags: { $regex : text, $options:"i" } });
要转义特殊字符,您可以在使用text
之前执行此操作(来自JQuery UI的源代码)
text = text.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g, "\\$&");
答案 1 :(得分:5)
在服务器的发布功能中尝试:
return YourCollection.find({'$or' : [
{ 'field1':{'$regex':searchString} },
{ 'field2':{'$regex':searchString} },
{ 'field3':{'$regex':searchString} }, ]
});