MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Jak ZAMÓWIĆ WEDŁUG WARTOŚCI POLA w MongoDB

Możemy użyć $indexOfArray

Konsola

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

Kod PHP

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


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Jak zachować wartości null na końcu sortowania w Mongoose?

  2. Jak wysłać obiekt z MongoDB do jadeitu?

  3. Dla let, nie inkrementuj, jeśli w tablicy znajduje się ten sam element

  4. Ignoruj ​​połączenie z gniazdem MongoDB podczas testu wiosennego

  5. Filtruj elementy tablicy za pomocą $regex