我正在尝试将名字和姓氏作为全名,因为我正在设置模型
"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);
})
答案 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
聚合运算符将firstName
和lastName
作为fullName
chatUsersModel.aggregate([{
'$project' : {
'fullName' : {'$concat' : [ '$firstName', ' ' ,'$lastName' ]}
}
}]);