gpt4 book ai didi

node.js - Express js Mongoose 替代 MySQL % 通配符

转载 作者:太空宇宙 更新时间:2023-11-04 00:55:16 24 4
gpt4 key购买 nike

我一直在阅读并尝试了一些其他人已经成功使用的不同代码片段,但我似乎无法让它工作。

我希望用户仅使用术语的一部分进行搜索,即 pe 代表“peter”。我想在搜索词上使用通配符。

到目前为止,我的代码不起作用:

router.get('/:callsign', function(req,res){
var search = req.params.callsign;
var term = escape(search);
term = term.toUpperCase();
if(search=="*" || search==""){
res.redirect("/");
}
User.find({'callsign' : new RegExp('^'+term+'$', "i") }, function(err, callsign){
if(err)
{
console.log('No user found'+err);
req.flash('message','Sorry, something went wrong. Try again.');
res.render('callSearchResults'),{
message: req.flash('message'),
title: 'Sorry, no results'
}
}
if(callsign){
console.log('Callsign:'+callsign+term);
res.render('callSearchResults',{
call: callsign,
title: 'You searched for '+search,
query: term
});
}else{
console.log('No entries found'+search);
}
});
});

此外,“callsign”回调始终为 true - 即使没有结果!

最佳答案

您正在使用 RegExp对于这次搜索。字面量 ^ 表示模式必须位于字符串的开头,而 $ 则位于字符串末尾。如果您只想匹配部分,则不需要添加它们,例如下面的示例:

new RegExp(term, "i")

mongo 内置了一个很好的全文搜索机制。您可以从官方docs了解它们。

关于 mongoose 中的查询,当现在有对象并检查回调时。返回的对象是文档数组,在 JS 中空数组被转换为 true 语句。相反,检查长度数组,如下所示:

if(callsign.length > 0) {
// Logic
} else {
// Nothing found
}

关于node.js - Express js Mongoose 替代 MySQL % 通配符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30138625/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com