sql >> Databasteknik >  >> NoSQL >> MongoDB

Hur man BESTÄLLER PER FÄLTVÄRDE i MongoDB

Vi kan använda $indexOfArray

Konsol

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

PHP-kod

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


  1. socket.io net::ERR_CONNECTION_CLOSED

  2. Skriv din första rådgivare

  3. Hoppa över och begränsa för sidnumrering för ett Mongo-aggregat

  4. DAO och beroendeinjektion, råd?