Docs Menu
Docs Home
/
MongoDBマニュアル
/ / /

$dateTrunc(集計)

項目一覧

  • 定義
  • 動作
$dateTrunc

バージョン 5.0 で追加

日付を切り捨てます。

$dateTrunc 構文:

{
$dateTrunc: {
date: <Expression>,
unit: <Expression>,
binSize: <Expression>,
timezone: <tzExpression>,
startOfWeek: <Expression>
}
}
フィールド
必須または任意
説明

date

必須

切り捨てる日付(UTC で指定)。日付 には、 日付 タイムスタンプ 、または オブジェクト ID に解決される任意の式を指定できます。

必須

時間の単位。として指定され、次のいずれかの文字列に解決される必要があります。

  • year

  • quarter

  • week

  • month

  • day

  • hour

  • minute

  • second

binSize unit $dateTruncは、 計算で使用される期間を指定します。

任意

数値の時間値。として指定され、ゼロ以外の正の数値に解決される必要があります。デフォルトは 1 です。

binSize unit $dateTruncは、 計算で使用される期間を指定します。

任意

$dateTrunc計算のタイムゾーン。式として指定され、次のいずれかの値を含む string に解決される必要があります。

タイムゾーンが指定されていない場合、 計算は UTC$dateTrunc で実行されます。

形式

Olson タイムゾーン識別子

  • America/New_York

  • Europe/London

  • GMT

UTC オフセット

  • +/-[hh]:[mm] (例: +04:45

  • +/-[hh][mm] (例: -0530

  • +/-[hh] (例: +03

任意

週の開始。 ユニットがweek の場合に使用されます。デフォルトは Sunday です。

startOfWeek は、大文字と小文字を区別しない文字列のいずれかに変換される必要がある式です。

  • monday (または mon

  • tuesday (または tue

  • wednesday (または wed

  • thursday (または thu

  • friday (または fri

  • saturday (または sat

  • sunday (または sun

Tip

以下も参照してください。

$dateTrunc:

binSizeunitは、 $dateTrunc計算で使用される期間を指定します。

以下に例を挙げます。

  • binSize1で、 unithourの場合、期間は 1 時間です。 日付2021-03-20T11:30:05Zの場合、 $dateTrunc2021-03-20T11:00:00Zを返します。

  • binSize2で、 unithourの場合、期間は 2 時間です。 日付2021-03-20T11:30:05Zの場合、 $dateTrunc2021-03-20T10:00:00Zを返します。

$dateTrunc:

  • 計算の時間を指定された時間 単位$dateTrunc binSize 期間に分割します。

    期間は、ユニットによって決定される基準日から始まります。ユニットが次の場合。

    • week以外の string では、 $dateTrunc2000-01-01T00:00:00.00Zの参照日を使用します。 たとえば、 binSize10で、 unityearの場合、期間の例は次のようになります。

      • 2000-01-01T00:00:00.00Z

      • 2010-01-01T00:00:00.00Z

      • 2020-01-01T00:00:00.00Z

    • weekと等しい場合、 $dateTruncは、 2000-01-01以上の週の最も近い最初の日に設定された参照日を使用します。 最初の日はstartOfWeekを使用して設定されます(デフォルトは日曜日)。

  • 日付が含まれる期間の下限を返します。 境界はISODateとして返されます。 binSize フィールドが1 の場合、 は返された$dateTrunc ISODate の最下位部分( ユニット によって決定)を に設定し、0 ISODate の残りの部分を同じままにします。

ユニットが次の場合。

ユニットが次の場合。

  • week以外の string では、 startOfWeekは無視されます。

  • weekと等しく、 startOfWeekは次のとおりです。

    • 指定: $dateTruncstartOfWeekを計算の最初の日として startOfWeek を使用します。

    • 省略: $dateTruncは日曜日を計算の週の開始として使用します。

カリフォルニア州(CA)とワシントン州(WA)のケーキ販売を含む cakeSales コレクションを作成します。

db.cakeSales.insertMany( [
{ _id: 0, type: "chocolate", orderDate: new Date("2020-05-18T14:10:30Z"),
state: "CA", price: 13, quantity: 120 },
{ _id: 1, type: "chocolate", orderDate: new Date("2021-03-20T11:30:05Z"),
state: "WA", price: 14, quantity: 140 },
{ _id: 2, type: "vanilla", orderDate: new Date("2021-01-11T06:31:15Z"),
state: "CA", price: 12, quantity: 145 },
{ _id: 3, type: "vanilla", orderDate: new Date("2020-02-08T13:13:23Z"),
state: "WA", price: 13, quantity: 104 },
{ _id: 4, type: "strawberry", orderDate: new Date("2019-05-18T16:09:01Z"),
state: "CA", price: 41, quantity: 162 },
{ _id: 5, type: "strawberry", orderDate: new Date("2019-01-08T06:12:03Z"),
state: "WA", price: 43, quantity: 134 }
] )

次の例では、 cakeSalesコレクションが使用されています。

この例では、 ステージで$dateTrunc $projectを使用して、ケーキ販売orderDate の値を 2 週間に切り捨てています。

db.cakeSales.aggregate( [
{
$project: {
_id: 1,
orderDate: 1,
truncatedOrderDate: {
$dateTrunc: {
date: "$orderDate", unit: "week", binSize: 2,
timezone: "America/Los_Angeles", startOfWeek: "Monday"
}
}
}
}
] )

この例では、次のことが行われます。

  • $project は、出力に _idorderDate、および truncatedOrderDate フィールドを含めます。

  • $dateTrunc は、 startOfWeek が に設定されているorderDate2 weekタイムゾーン のAmerica/Los_Angeles フィールドを binSize ユニット 期間を切り捨てます。Monday

この出力例では、切り捨てられた orderDatetruncatedOrderDate フィールドに表示されます。

[
{
_id: 0,
orderDate: ISODate("2020-05-18T14:10:30.000Z"),
truncatedOrderDate: ISODate("2020-05-11T07:00:00.000Z")
},
{
_id: 1,
orderDate: ISODate("2021-03-20T11:30:05.000Z"),
truncatedOrderDate: ISODate("2021-03-15T07:00:00.000Z")
},
{
_id: 2,
orderDate: ISODate("2021-01-11T06:31:15.000Z"),
truncatedOrderDate: ISODate("2021-01-04T08:00:00.000Z")
},
{
_id: 3,
orderDate: ISODate("2020-02-08T13:13:23.000Z"),
truncatedOrderDate: ISODate("2020-02-03T08:00:00.000Z")
},
{
_id: 4,
orderDate: ISODate("2019-05-18T16:09:01.000Z"),
truncatedOrderDate: ISODate("2019-05-13T07:00:00.000Z")
},
{
_id: 5,
orderDate: ISODate("2019-01-08T06:12:03.000Z"),
truncatedOrderDate: ISODate("2019-01-07T08:00:00.000Z")
}
]

この例では、 ステージで$dateTrunc $groupを使用して、ケーキ販売のorderDate 値を 6 か月に切り捨てて、 値の合計を返します。quantity

db.cakeSales.aggregate( [
{
$group: {
_id: {
truncatedOrderDate: {
$dateTrunc: {
date: "$orderDate", unit: "month", binSize: 6
}
}
},
sumQuantity: { $sum: "$quantity" }
}
}
] )

この例では、次のことが行われます。

  • $group _id フィールドを truncatedOrderDate フィールドに設定して cakeSales ドキュメントをグループ化し、$sum. を使用して各グループの quantity 値の合計を返します。

  • $dateTrunc は、 orderDateフィールドを6 binSize month単位の期間に切り捨てます。

この出力例では、切り捨てられた orderDatetruncatedOrderDate フィールドに表示され、quantity の合計が sumQuantity フィールドに表示されます。

[
{
_id: { truncatedOrderDate: ISODate("2020-01-01T00:00:00.000Z") },
sumQuantity: 224
},
{
_id: { truncatedOrderDate: ISODate("2021-01-01T00:00:00.000Z") },
sumQuantity: 285
},
{
_id: { truncatedOrderDate: ISODate("2019-01-01T00:00:00.000Z") },
sumQuantity: 296
}
]

戻る

$dateToString(集計)

項目一覧