“文档” 菜单
文档首页
/
MongoDB Manual
/ / /

$dateTrunc(聚合)

在此页面上

  • 定义
  • 行为
  • 举例
$dateTrunc

版本 5.0 中的新增功能

截断日期。

$dateTrunc 事务语法:

{
$dateTrunc: {
date: <Expression>,
unit: <Expression>,
binSize: <Expression>,
timezone: <tzExpression>,
startOfWeek: <Expression>
}
}
字段
必需/可选
说明
日期
必需

要截断的日期,以 UTC 格式指定。 日期 可以是解析为 Date Timestamp ObjectID 的任何 表达式 。

必需

时间单位,指定为必须解析为以下字符串之一的表达式

  • year

  • quarter

  • week

  • month

  • day

  • hour

  • minute

  • second

binSize单位共同指定了 $dateTrunc 计算中使用的时间段。

Optional

数值时间值,指定为必须解析为非零正数的表达式。默认为 1。

binSize单位共同指定了 $dateTrunc 计算中使用的时间段。

Optional

用于 $dateTrunc 计算的时区,以表达式形式指定,必须解析为包含以下值之一的字符串:

如果未提供时区$dateTrunc 将按照 UTC 时间进行计算。

format
举例
Olson 时区标识符
  • America/New_York

  • Europe/London

  • GMT

UTC 偏移
  • +/-[hh]:[mm] (例如,+04:45

  • +/-[hh][mm] (例如,-0530

  • +/-[hh] (例如,+03

Optional

一周的开始。当单位week 时使用。默认为 Sunday

startOfWeek 是一个必须解析为以下不区分大小写的字符串之一的表达式

  • monday (或 mon

  • tuesday (或 tue

  • wednesday (或 wed

  • thursday (或 thu

  • friday (或 fri

  • saturday (或 sat

  • sunday (或 sun

提示

另请参阅:

$dateTrunc

  • 如果出现以下情况,则返回 null

    • startOfWeek 之外的任何输入字段均缺失或设置为 null,或者

    • 如果单位weekstartOfWeek 缺失或设置为 null

  • 使用外推格里历表示 1583 年以前的日期。

  • 考虑夏令时,但不考虑 闰秒。

binSize单位共同指定了 $dateTrunc 计算中使用的时间段。

例如:

  • 如果 binSize1unithour,则时间段为一小时。对于日期 2021-03-20T11:30:05Z$dateTrunc 返回 2021-03-20T11:00:00Z

  • 如果 binSize2单位hour,则时间段为两小时。对于日期 2021-03-20T11:30:05Z$dateTrunc 返回 2021-03-20T10:00:00Z

$dateTrunc

  • $dateTrunc 计算的时间按照指定的时间单位分成 binSize 时间段。

    时间段从参考日期开始,而该参考日期由单位确定。如果单位为:

    • week 以外的字符串,$dateTrunc2000-01-01T00:00:00.00Z 作为参考日期。例如,如果 binSize10单位year,则示例时间段为:

      • 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 的其余部分不变。

如果 unit 为:

如果 unit 为:

创建cakeSales集合,其中包含加利福尼亚州 ( CA ) 和华盛顿州 ( WA ) 的蛋糕销售情况:

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 集合。

此示例在 $project 阶段中使用 $dateTrunc 将蛋糕销售 orderDate 值截断为两周:

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

在示例中:

  • $project 在输出中包含 _idorderDatetruncatedOrderDate 字段。

  • $dateTrunc 会将 orderDate 字段截断成 2 binSizeweek单位的时间段,时区America/Los_AngelesstartOfWeek 设置为 Monday

在此示例输出中,截断的 orderDate 显示在 truncatedOrderDate 字段中:

[
{
_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")
}
]

该示例在 $group 阶段使用 $dateTrunc 将蛋糕销售额 orderDate 值截断为 6 个月,并返回 quantity 值的总和:

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

在示例中:

在此示例输出中,截断的 orderDate 显示在 truncatedOrderDate 字段中,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(聚合)

来年

$dayOfMonth(聚合)

在此页面上