sql >> Database teknologi >  >> NoSQL >> MongoDB

Sådan BESTILLER du EFTER FELTVÆRDI i MongoDB

Vi kan bruge $indexOfArray

Konsol

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

PHP-kode

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


  1. redis store 128 bit nummer

  2. Hvad er MongoDB batch operation max størrelse?

  3. Hvad er InputSplit i Hadoop MapReduce?

  4. Mongoose finde de sidste ti poster i databasen