javascript - 如何在 Mongoose 排序结束时保持空值?
问题描述
我正在根据属性查询集合和排序结果。有些文档还没有该属性值,即 null。在排序和限制(asc 或 desc)之后,我想在结果末尾保留具有空值的文档。Mongoose 中是否有一种简单的方法可以使用单个查询来做到这一点?如果没有,我如何分别使用两个查询,因为我必须限制结果以及分页?
var dealSchema = new Schema({
// For Presentation Purposes Only
dealId: { type: Number, index: true, unique: true },
// BRAND Info
brand: { type: ObjectId, ref: 'brand', index: true },
brandUser: { type: ObjectId, ref: 'user', index: true, required: true },
campaign: { type: ObjectId, ref: 'campaign', index: true },
metrics: {
totalCost: Number,
totalValue: Number,
roi: { type: Number, index: true },
cpe: { type: Number, index: true }
}
})
我想根据“metrics.cpe”按升序排序,但希望 null 或 0 值位于列表的末尾。例子:
[0.1, 0.4, 0.7, 1.5, 2.5, 0, 0, null, null]
样本文件
{
"_id": "590cdf29c102ae31208fa43a",
"campaign": "587e6a880c844c6c2ea01563",
"brand": "5a4cff5f8eaa1c26ca194acc",
"brandUser": "57fd30cf0df04f1100153e07",
"metrics": {
"roi": 0,
"cpe": 0,
"totalValue": 0,
"totalCost": 6000
}
}
解决方案
我不确定我要说的解决方案。我无法测试这一点,因为我现在没有设置 mongo db ,但我认为你可以使用<collection>.aggregate
并实现这一点。$project
$sort
示例代码:
db.inventory.aggregate(
[
{
$project: {
item: 1,
description: { $ifNull: [ "$amount", -1*(<mimimum value>)* ] }
}
},
{
$sort : {
amount : (-1 or 1 depending on the order you want)
}
}
]
)
希望这可以帮助 !!
推荐阅读
- postgresql - 如何编写正确/有效的查询
- spring-data-jpa - Spring Data Rest - 带有关系的 POST 不会保留依赖实体
- swift - 调用 draw() 函数时使用什么参数?
- php - Apache 错误: AH00422: Parent: Received shutdown signal -- 关闭服务器
- typescript - 使用对象数组中的数据在循环中量角器 it() 规范
- javascript - 如何在服务工作者获取中检测到请求是针对清单的 start_url 的?
- python - Python :concurrent.futures 多次执行整个代码,而不是在 Executor.submit() 中调用的函数
- string - laravel-用字符串连接对象类名
- python - 将变量从类方法函数调用到普通方法
- android - 如何在现有方法中添加一些生成的代码