如何解决如何使用切换条件基于多个条件进行查询并基于聚合mongodb中的结果派生新字段?
我需要根据课程查询用户集合,并且需要在结果中添加一个自定义字段,即状态。非常感谢您的帮助。
我的用户架构:
[
{
_id: 1,name: "abc",course: "java",password: "Password1",feePaid: true
},{
_id: 2,name: "def",course: "python",password: "Password2",{
_id: 3,name: "xyz",password: "Password3",feePaid: false
},{
_id: 4,name: "ghi",{
_id: 5,name: "lol",password: "Passswwword",feePaid: false
}
];
导出状态的逻辑:
- 未注册:如果密码字段不存在
- 有效:FeePaid为true
- 无效:如果FeePadid为假
我的查询是基于课程并获取自定义字段-状态来获取用户
const allUsers = await users.aggregate([
{
$match: {
{ course: "java" }
}
},{
$addFields: {
status: {
$switch: {
branches: [
{ "case": { "$ifNull": [ "$password",false ] },"then": "NotRegistered" },{ "case": { "$eq": [ "$feePaid",true ] },"then": "Active" },"then": "Inactive" }
],default: null
}
}
}
}
]);
预期结果-应包含各自的状态
[
{
_id: 1,feePaid: true,status: "Active"
},feePaid: false,status: "Inactive"
},status: "NotRegistered"
},status: "Inactive"
}
];
我的结果-我将所有状态都设为null。不确定为什么不进入开关箱
[
{
_id: 1,status: null
},status: null
},status: null
}
];
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。