$和[$或[]]的MongoDB聚合框架
我有一个Mongo集合,看起来像是
[
{
"city_town": "Melbourne",
"visit_date": "2022-06-22T14:00:00.000Z",
"payment_cleared_at": "2022-06-22T14:00:00.000Z"
},
{
"city_town": "Perth",
"visit_date": "2022-06-22T14:00:00.000Z",
"payment_cleared_at": "2022-06-22T14:00:00.000Z"
},
{
"city_town": "Perth",
"visit_date": "2022-06-22T14:00:00.000Z",
"payment_cleared_at": "2022-06-22T14:00:00.000Z"
},
{
"city_town": "Perth",
"visit_date": "2022-06-22T14:00:00.000Z",
"payment_cleared_at": "2022-06-22T14:00:00.000Z"
},
{
"city_town": "Perth",
"visit_date": "2022-06-22T14:00:00.000Z",
"payment_cleared_at": "2022-06-22T14:00:00.000Z"
}
]
我想在集合上进行聚合,以减去两个日期字段来排序。 这就是我现在正在做的事情,
db.collection.aggregate([
{
$match: {
"$and": [
{
"$or": [
{
"city_town": "Melbourne",
"visit_date": {
"$gte": "2022-06-22T14:00:00.000Z",
"$lte": "2022-06-23T13:59:59.999Z"
}
},
{
"city_town": "Perth",
"visit_date": {
"$gte": "2022-06-22T14:30:00.000Z",
"$lte": "2022-06-23T14:29:59.999Z"
}
}
]
},
{
"$or": [
{
"city_town": "Melbourne",
"payment_cleared_at": {
"$gte": "2022-06-14T14:00:00.000Z",
"$lte": "2022-06-15T13:59:59.999Z"
}
},
{
"city_town": "Perth",
"payment_cleared_at": {
"$gte": "2022-06-14T14:30:00.000Z",
"$lte": "2022-06-15T14:29:59.999Z"
}
}
]
}
]
}
},
{
$project: {
"time_diff": {
"$subtract": [
"$visit_date",
"$payment_cleared_at"
]
}
}
},
{
$sort: {
"visit_date": 1,
"time_diff": -1
}
},
{
$skip: 10
},
{
$limit: 10
}
])
因为它有$和。有没有办法实现相同的结果?
I have a Mongo collection which looks like this
[
{
"city_town": "Melbourne",
"visit_date": "2022-06-22T14:00:00.000Z",
"payment_cleared_at": "2022-06-22T14:00:00.000Z"
},
{
"city_town": "Perth",
"visit_date": "2022-06-22T14:00:00.000Z",
"payment_cleared_at": "2022-06-22T14:00:00.000Z"
},
{
"city_town": "Perth",
"visit_date": "2022-06-22T14:00:00.000Z",
"payment_cleared_at": "2022-06-22T14:00:00.000Z"
},
{
"city_town": "Perth",
"visit_date": "2022-06-22T14:00:00.000Z",
"payment_cleared_at": "2022-06-22T14:00:00.000Z"
},
{
"city_town": "Perth",
"visit_date": "2022-06-22T14:00:00.000Z",
"payment_cleared_at": "2022-06-22T14:00:00.000Z"
}
]
I want to do aggregation on the collection to sort by subtracting two date fields.
This is what I am doing right now
db.collection.aggregate([
{
$match: {
"$and": [
{
"$or": [
{
"city_town": "Melbourne",
"visit_date": {
"$gte": "2022-06-22T14:00:00.000Z",
"$lte": "2022-06-23T13:59:59.999Z"
}
},
{
"city_town": "Perth",
"visit_date": {
"$gte": "2022-06-22T14:30:00.000Z",
"$lte": "2022-06-23T14:29:59.999Z"
}
}
]
},
{
"$or": [
{
"city_town": "Melbourne",
"payment_cleared_at": {
"$gte": "2022-06-14T14:00:00.000Z",
"$lte": "2022-06-15T13:59:59.999Z"
}
},
{
"city_town": "Perth",
"payment_cleared_at": {
"$gte": "2022-06-14T14:30:00.000Z",
"$lte": "2022-06-15T14:29:59.999Z"
}
}
]
}
]
}
},
{
$project: {
"time_diff": {
"$subtract": [
"$visit_date",
"$payment_cleared_at"
]
}
}
},
{
$sort: {
"visit_date": 1,
"time_diff": -1
}
},
{
$skip: 10
},
{
$limit: 10
}
])
It doesn't work since it has an $and. Is there a way to achieve the same result?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
以下查询作品。第二个
$或
案例没有任何值,这就是为什么$和
不起作用的原因。我更改了价值和时间差异。工作 mongo playground
Following query works. The second
$or
case doesn't give you any value, thats why$and
doesn't work. I changed the value and time diff.Working Mongo playground