查询firstname,lastname作为fullname

时间:2018-04-05 06:47:11

标签: node.js mongodb mongoose mongodb-query aggregation-framework

我正在尝试将名字和姓氏作为全名,因为我正在设置模型

      "chatBotId": String,
        "firstName":String,
        "lastName":String,
        "contactId" : String,
        "type" : String,
         "userId":String,
        "BotResponseBlocked": Boolean
    }
);

chatUserSchema.virtual('fullName').get(function(){

    return this.firstName+' '+ this.lastName;
})

但我的查询并没有返回全名。

chatUsersModel.find({chatBotId:chatBotId},{'_id':0,'userId':1, 'firstName':1, 'lastName':1}).lean().
            exec((err,result)=>{

            callback(result);
        })  

2 个答案:

答案 0 :(得分:0)

使用 lean()功能意味着您的查询结果将只是JavaScript对象而没有任何猫鼬的东西。

这意味着您不会获得虚拟内容。

您可以从查询中删除精益(),或者您可以使用一个插件将虚拟广告包含在名为 mongoose-lean-virtuals 的精简查询中:

const mongooseLeanVirtuals = require('mongoose-lean-virtuals')

// ...

chatUserSchema
  .virtual('fullName')
  .get(function() {
    return this.firstName + ' ' + this.lastName
  })

// Use plugin after defining virtuals
chatUserSchema
  .plugin(mongooseLeanVirtuals)

您可以告诉精简()包含以下虚拟内容:

chatUsersModel
  .find({ ... })
  .lean({ virtuals: true })
  .exec((err, result) => {
    callback(result)
  })  

现在应该在结果中包含您的虚拟内容。

我希望这会有所帮助。

答案 1 :(得分:0)

您可以使用$concat聚合运算符将firstNamelastName作为fullName

chatUsersModel.aggregate([{
  '$project' : {  
    'fullName' : {'$concat' : [ '$firstName', ' ' ,'$lastName' ]}
  }
}]);