我想运行一个正则表达式来在我的用户模式中的虚拟字段上实现“LIKE”类型功能.
以下语句适用于除* fullName *之外的所有字段
var searchString = stringUtils.removeMultipleSpaces(stringUtils.stripSpecialCharacters(req.param('searchString'))); var regex = new RegExp(searchString); var query = User.find().or([{ 'firstName' : { $regex: regex}},{ 'lastName': { $regex: regex }},{ 'userName': { $regex: regex }},{ 'fullName' : {$regex: regex }}]).sort('lastName'); query.select('firstName lastName userName fullName'); query.exec(function(err,users) { res.send(users); });
用户的mongoose模式中的虚拟字段声明
//full name UserSchema.virtual('fullName') .get(function() { return this.firstName + ' ' + this.lastName; });
使fullName字段正则表达式正常工作的正确方法是什么?
解决方法
正如您已经说过的(并向我们展示),fullName是虚拟的,它位于应用程序层.你不能查询它.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。