node.js – 虚拟字段上的Mongoose Regex

我想运行一个正则表达式来在我的用户模式中的虚拟字段上实现“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是虚拟的,它位于应用程序层.你不能查询它.

另见:Sorting by virtual field in mongoDB (mongoose)

相关文章

这篇文章主要介绍“基于nodejs的ssh2怎么实现自动化部署”的...
本文小编为大家详细介绍“nodejs怎么实现目录不存在自动创建...
这篇“如何把nodejs数据传到前端”文章的知识点大部分人都不...
本文小编为大家详细介绍“nodejs如何实现定时删除文件”,内...
这篇文章主要讲解了“nodejs安装模块卡住不动怎么解决”,文...
今天小编给大家分享一下如何检测nodejs有没有安装成功的相关...