MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Как да групирате датите по тримесечие?

Можете да използвате $cond оператор, за да провери дали:

  • $month е <= 3 , проектирайте поле с име quarter със стойност като "едно".
  • $month е <= 6 , проектирайте поле с име quarter със стойност като "две".
  • $month е <= 9 , проектирайте поле с име quarter със стойност като "три".
  • иначе стойността на полето quarter ще бъде "четвърто".
  • След това $group от quarter поле.

Код:

db.collection.aggregate([
  {
    $project: {
      date: 1,
      quarter: {
        $cond: [
          { $lte: [{ $month: "$date" }, 3] },
          "first",
          {
            $cond: [
              { $lte: [{ $month: "$date" }, 6] },
              "second",
              {
                $cond: [{ $lte: [{ $month: "$date" }, 9] }, "third", "fourth"],
              },
            ],
          },
        ],
      },
    },
  },
  { $group: { _id: { quarter: "$quarter" }, results: { $push: "$date" } } },
]);

Специфично за вашата схема:

db.collection.aggregate([
  {
    $project: {
      dateAttempted: 1,
      userId: 1,
      topicId: 1,
      ekgId: 1,
      title: 1,
      quarter: {
        $cond: [
          { $lte: [{ $month: "$dateAttempted" }, 3] },
          "first",
          {
            $cond: [
              { $lte: [{ $month: "$dateAttempted" }, 6] },
              "second",
              {
                $cond: [
                  { $lte: [{ $month: "$dateAttempted" }, 9] },
                  "third",
                  "fourth",
                ],
              },
            ],
          },
        ],
      },
    },
  },
  { $group: { _id: { quarter: "$quarter" }, results: { $push: "$$ROOT" } } },
]);


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. NestJS:Как да внедрите потребителско удостоверяване, базирано на сесия

  2. Не може да се удостовери в mongo, удостоверяването е неуспешно

  3. Как програмно предварително да разделите ключ на шард, базиран на GUID, с MongoDB

  4. MongoDB, MapReduce и сортиране

  5. MongoDB findAndModify()