sql >> Databáze >  >> NoSQL >> MongoDB

Agregace MongoDB s ovladačem Java

Nakonec jsem našel řešení, dostanu stejný výsledek než s původním požadavkem.

Ovladač Mongo 3:

Souhrnný dokument

MongoCollection<Document> collection = database.getCollection("myCollection");

AggregateIterable<Document> output = collection.aggregate(Arrays.asList(
        new Document("$unwind", "$views"),
        new Document("$match", new Document("views.isActive", true)),
        new Document("$sort", new Document("views.date", 1)),
        new Document("$limit", 200),
        new Document("$project", new Document("_id", 0)
                    .append("url", "$views.url")
                    .append("date", "$views.date"))
        ));

// Print for demo
for (Document dbObject : output)
{
    System.out.println(dbObject);
}

Pomocí statického importu můžete zvýšit čitelnost:
import static com.mongodb.client.model.Aggregates.*; .
Kompletní příklad viz odpověď koulini.

Ovladač Mongo 2:

Souhrnný dokument

Iterable<DBObject> output = collection.aggregate(Arrays.asList(
        (DBObject) new BasicDBObject("$unwind", "$views"),
        (DBObject) new BasicDBObject("$match", new BasicDBObject("views.isActive", true)),
        (DBObject) new BasicDBObject("$sort", new BasicDBObject("views.date", 1)),
        (DBObject) new BasicDBObject("$limit", 200),
        (DBObject) new BasicDBObject("$project", new BasicDBObject("_id", 0)
                    .append("url", "$views.url")
                    .append("date", "$views.date"))
        )).results();
    
// Print for demo
for (DBObject dbObject : output)
{
    System.out.println(dbObject);
}

Logika konverze dotazu: Díky tomuto odkazu



  1. Jak uložit v Redis tříděné sadě s časovým razítkem na straně serveru jako skóre?

  2. $first v mongodb

  3. Změna výchozího oprávnění k souboru na redis dump

  4. Jak zachytit výjimku při vytváření instance MongoClient