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

jak spustit nativní dotaz mongodb s funkcí data mongodb v spring-data-mongodb?

Můžete použít mongoTemplate.executeCommand(DBObject dbObject) varianta.

Stačí změnit datum na rozšířený json, který je podporován analyzátorem Json, a sestavit příkaz.

Něco jako

long date1 = Instant.parse("2016-07-25T10:33:04.196Z").toEpochMilli();
long date2 = Instant.parse("2018-07-25T10:33:04.196Z").toEpochMilli();

DBObject dbObject = new BasicDBObject(
    "aggregate", "mycollection").append(
    "pipeline", JSON.parse("[\n" +
        "  {\n" +
        "    \"$match\": {\n" +
        "      \"$and\": [\n" +
        "        {\n" +
        "          \"orderDate\": {\n" +
        "            \"$gte\": \""+ date1 +"\"\n" +
        "          }\n" +
        "        },\n" +
        "        {\n" +
        "          \"orderDate\": {\n" +
        "            \"$gte\": \""+ date2 +"\"\n" +
        "          }\n" +
        "        }\n" +
        "      ]\n" +
        "    }\n" +
        "  },\n" +
        "  {\n" +
        "    \"$project\": {\n" +
        "      \"orderType\": 1,\n" +
        "      \"count\": 1,\n" +
        "      \"month\": {\n" +
        "        \"$month\": [\n" +
        "          \"$orderDate\"\n" +
        "        ]\n" +
        "      }\n" +
        "    }\n" +
        "  },\n" +
        "  {\n" +
        "    \"$group\": {\n" +
        "      \"_id\": {\n" +
        "        \"month\": \"$month\",\n" +
        "        \"orderType\": \"$orderType\"\n" +
        "      },\n" +
        "      \"count\": {\n" +
        "        \"$sum\": 1\n" +
        "      }\n" +
        "    }\n" +
        "  }\n" +
    "]")).append(
    "cursor", new BasicDBObject("batchSize", 1000)
);

mongoTemplate.executeCommand(dbObject)



  1. Modul nenalezen:Chyba:Nelze vyřešit modul 'modul' mongodb při sbalení s webpackem

  2. MongoDB načte pouze odpovídající dílčí dokumenty z dokumentu s c#

  3. Kam psát a ukládat mongoDB mapové/redukční funkce v projektu Java

  4. Připojte se k AWS ElastiCache pomocí In-Transit Encryption