NodeJS MongoDb $ sort не работает в агрегированном запросе - PullRequest
0 голосов
/ 30 октября 2019

Я создал GET API для результатов, с фильтрами, нумерацией страниц и сортировкой. Но хотя данные верны, сортировка происходит неправильно.

let skip = 0, limit = 10, findCond = {centerId: self.centersModel.getObjectId(userData.id)};
if(queryParams.result) findCond['result'] = {"$regex": queryParams.result, "$options": 'i'};

if(queryParams.fromDate) findCond['created_at'] = {$gte: moment(queryParams.fromDate + ' 00:00:00', 'DD-MM-YYYY HH:mm:ss').toDate()};
if(queryParams.toDate) {
    if(findCond.hasOwnProperty('created_at')) findCond['created_at']['$lte'] = moment(queryParams.toDate + ' 23:59:59', 'DD-MM-YYYY HH:mm:ss').toDate();
    else findCond['created_at'] = {$lte: moment(queryParams.toDate + ' 23:59:59', 'DD-MM-YYYY HH:mm:ss').toDate()};
}

if(queryParams.perPage) limit = parseInt(queryParams.perPage);
if(queryParams.page) skip = (parseInt(queryParams.page) - 1) * limit;

let aggregate = [
    { "$match": findCond },
    { "$sort": {"created_at": 1} },
    { "$skip": skip },
    { "$limit": limit }
];
console.log(aggregate)
self.resultsModel.aggregate(aggregate, function(err, results) {
    console.log(err, results);
});

Результат :

{
    "status": "ok",
    "results": [
        {
            "id": "5db83e69fcee977a20b24260",
            "result": "Pass",
            "examDate": "29/10/2019 06:58 PM"
        },
        {
            "id": "5db6b4d33ffd7d3ccde175d1",
            "result": "Pass",
            "examDate": "28/10/2019 08:38 PM"
        },
        {
            "id": "5db83e9bfcee977a20b24262",
            "result": "Pass",
            "examDate": "29/10/2019 06:58 PM"
        },
        {
            "id": "5db83ecafcee977a20b24264",
            "result": "Pass",
            "examDate": "29/10/2019 06:59 PM"
        },
        {
            "id": "5db83f40fcee977a20b24266",
            "result": "Fail",
            "examDate": "29/10/2019 07:01 PM"
        },
        {
            "id": "5db84395bb402b0f3de43ff7",
            "result": "Pass",
            "examDate": "29/10/2019 07:20 PM"
        },
        {
            "id": "5db843c0bb402b0f3de43ff9",
            "result": "Pass",
            "examDate": "29/10/2019 07:20 PM"
        }
    ]
}

Одна из дат - 28 /10/2019 между 29/10. Пожалуйста, сообщите мне причину или решение этой проблемы.

1 Ответ

0 голосов
/ 30 октября 2019

Я думаю, чтобы избежать путаницы, вы должны поделиться значением зарегистрированной агрегированной переменной, а не ответом, который вы создаете после применения к ней преобразования.

...