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

Jak pogrupować datę kwartalnie?

Możesz skorzystać z $cond operator, aby sprawdzić, czy:

  • $month to <= 3 , rzutuj pole o nazwie quarter z wartością jako „jeden”.
  • $month to <= 6 , rzutuj pole o nazwie quarter z wartością jako „dwa”.
  • $month to <= 9 , rzutuj pole o nazwie quarter z wartością jako „trzy”.
  • w przeciwnym razie wartość pola quarter byłoby „czwarte”.
  • Wtedy $group przez quarter pole.

Kod:

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" } } },
]);

Specyficzne dla Twojego schematu:

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. Importuj dane csv jako tablicę w mongodb za pomocą mongoimport

  2. Parametry połączenia w MongoDB (z przykładami)

  3. TransactionRequiredException Wykonywanie zapytania aktualizującego/usuwającego

  4. Element ściągający MongoDB z tablicy o głębokości dwóch poziomów

  5. Wykryj, czy wartość zawiera co najmniej jedną cyfrę w SQL