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

MongoDB Java — wypychanie do zagnieżdżonej tablicy?

Możesz odwoływać się do tablicy w poddokumencie „poziom1” za pomocą notacji kropkowej. Tak więc, zamiast tworzyć zagnieżdżone DBObjects, tak jak to zrobiłeś, po prostu potrzebujesz:

coll.update(entry, new BasicDBObject("$push", new BasicDBObject("level1.arr1", "val2")));

Napisałem test, aby pokazać, że to działa:

@Test
public void shouldPushANewValueOntoANesstedArray() throws UnknownHostException {
    final MongoClient mongoClient = new MongoClient();
    final DBCollection coll = mongoClient.getDB("TheDatabase").getCollection("TheCollection");
    coll.drop();

    //Inserting the array into the database
    final BasicDBList array = new BasicDBList();
    array.add("val1");

    final BasicDBObject entry = new BasicDBObject("level1", new BasicDBObject("arr1", array));
    coll.insert(entry);

    // results in:
    // { "_id" : ObjectId("51a4cfdd3004a84dde78d79c"), "level1" : { "arr1" : [ "val1" ] } }

    //do the update
    coll.update(entry, new BasicDBObject("$push", new BasicDBObject("level1.arr1", "val2")));
    // results in:
    // { "_id" : ObjectId("51a4cfdd3004a84dde78d79c"), "level1" : { "arr1" : [ "val1", "val2" ] } }
}



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Wartości mangusty i pływaka

  2. Zapisywanie w Javie springdata dokumentu mongoDB z ograniczoną liczbą tablic ($slice i $sort)

  3. Jak połączyć stronę Laravel z atlasem mongoDB?

  4. Jak wyświetlić dowolne, schematyczne dane w HTML za pomocą node.js / mongodb

  5. Użyj mongoexport z --query dla ISODate