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

Co się stanie, jeśli odprężenie zostanie zastosowane do pola, którego nie ma podczas używania agregacji w manguście?

Nie, nie:

Oto prosty przykład:

> db.test.insert({a:[1]})
> db.test.insert({})

> db.test.aggregate({$unwind:'$a'})
{ "_id" : ObjectId("557362a17b97d77c38793c21"), "a" : 1 }
// no error -- but unwind only the document having the `a` field.

Ale:

> db.test.insert({a:2})
> db.test.aggregate({$unwind:'$a'})
// will result in error 15978:
// """Value at end of $unwind field path '$a' must be an Array,
//    but is a NumberDouble"""

Zgodnie z Twoją zmianą, jeśli chcesz zachować dokumenty z brakującym pole do rozwinięcia, możesz $project wartość domyślna przy użyciu $ifNull :

> db.test.find()
{ "_id" : ObjectId("557362a17b97d77c38793c21"), "a" : [ 1 ] }
{ "_id" : ObjectId("557362a57b97d77c38793c22") }

> db.test.aggregate([
    {$project: { a: { $ifNull: ['$a', [ null ]]}}},
    {$unwind: "$a"}
])
{ "_id" : ObjectId("557362a17b97d77c38793c21"), "a" : 1 }
{ "_id" : ObjectId("557362a57b97d77c38793c22"), "a" : null }



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Wdrażanie baz danych w chmurze za pomocą ClusterControl 1.6

  2. Mongodb java:Perist POJO klasa z polem generycznym

  3. Jak filtrować, aby zwrócić podzbiór schematu mangusty?

  4. Pobieranie MongoDB w systemie Linux do nasłuchiwania połączeń zdalnych

  5. Indeks tekstowy MongoDB we wszystkich polach przy użyciu języka Java