我有一个搜索功能,可以根据用户对各种过滤器的输入,从我的mongoDB返回过滤后的数据。所以,举例来说,我可以做到这一点并且有效:
if (lastName) {
let arrlastName = [];
arrlastName = lastName.split(",");
_.each(arrlastName, (l, key, c) => {
arrlastName[key] = new RegExp(arrlastName[key], "i");
});
search['name.last'] = { $in: arrlastName };
}
以上内容返回一个过滤后的数据集,其中的结果与用户在逗号分隔列表中传递的内容相匹配。
但是,我在使用mongo db中的用户输入值与_id
值进行比较时遇到了挑战。当然,我在这里检查的_id
不是一个字符串,而是一个mongo objectId - 就我所知,这就是问题所在。所以我试图找出如何转换输入或_id
或两者来进行有效比较。这是最初的代码:
if (person) search['_id'] = person;
这不起作用,因为person
这里的值是一个字符串,_id
不是 - 正如我所说,_id
是一个mongo objectId。那么如何进行类型转换来处理此检查呢?
我尝试了这个,但它会导致错误:
if (person) search['_id'].toString() = person;
这种比较的语法是什么样的?
答案 0 :(得分:2)
在mongoDB中,您可以使用ObjectId.valueOf()
ObjectId("507c7f79bcf86cd7994f6c0e").valueOf()
将返回以下字符串:
507c7f79bcf86cd7994f6c0e