流星& mongoDB LIKE查询

时间:2013-04-15 16:39:30

标签: mongodb meteor

我试图根据用户搜索的内容生成查询。我有一个字符串数组,我只想在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});

但这并没有给我任何结果。我错过了什么?

2 个答案:

答案 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} }, ]
});