sql >> Databáze >  >> NoSQL >> MongoDB

Jak OBJEDNAT PODLE HODNOTY POLE v MongoDB

Můžeme použít $indexOfArray

Konzole

db.collectionName.aggregate([{
    $match: {
        _id: {
            $in: [249, 244]
        }
    }
}, {
    $addFields: {
        sort: {
            $indexOfArray: [
                [249, 244], "$_id"
            ]
        }
    }
},{
    $sort: {
        sort: 1
    }
}])

PHP kód

$data = $this->mongo->{$collectionName}->aggregate(
    [
        [
            '$match' => ['_id' => ['$in' => $idList]]
        ],
        [
            '$addFields' => ['sort' => ['$indexOfArray' => [$idList, '$_id']]]
        ],
        [
            '$sort' => ['sort' => 1]
        ],
        [
            '$project' => [
                'name' => 1
            ]
        ]
    ]
);


  1. pozadí mongo createIndex blokuje shell

  2. Dotaz mezi daty v MongoDB

  3. MongoDB Failing to Start - ***přerušení po selhání fassert().

  4. Nasazení aplikace node js, která používá mongo db na aws