文档菜单
文档首页
/
MongoDB 手册
/ / /

$dateTrunc(聚合)

本页内容

  • 定义
  • 行为
  • 示例
$dateTrunc

在版本5.0.

截断日期。

$dateTrunc 语法

{
$dateTrunc: {
date: <Expression>,
unit: <Expression>,
binSize: <Expression>,
timezone: <tzExpression>,
startOfWeek: <Expression>
}
}
字段
必需 / 可选
描述
必需

要截断的日期,以UTC指定。日期可以是任何表达式,该表达式解析为日期时间戳ObjectID

必需

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

  • 季度

  • 小时

  • 分钟

一起,binSizeunit 指定了 $dateTrunc 计算中使用的时间段。

可选

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

一起,binSizeunit 指定了 $dateTrunc 计算中使用的时间段。

可选

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

如果没有提供任何 时间区域,则 $dateTrunc 计算将在 UTC 中执行。

格式
示例
Olson 时间区域标识符
  • 美洲/纽约

  • 欧洲/伦敦

  • 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

提示

另请参阅

$dateTrunc:

一起,binSizeunit 指定了 $dateTrunc 计算中使用的时间段。

例如

  • 如果binSize1并且unithour,时间段是一小时。对于日期2021-03-20T11:30:05Z$dateTrunc返回2021-03-20T11:00:00Z

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

$dateTrunc:

  • $dateTrunc 计算的时间划分为指定时间 unitbinSize 时间段。

    时间段从参考日期开始,参考日期由 unit 决定。

    • 如果不是 week 的字符串,$dateTrunc 使用参考日期 2000-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(默认为星期日)设置。

  • 返回 date 所在的时间段的下限。边界以 ISODate 返回。如果 binSize 字段为 1$dateTrunc 将返回的 ISODate 的最低有效部分(由 unit 确定)设置为 0,并保持其余部分不变。

如果 unit

如果 unit

  • 除了 startOfWeek 之外的其他字符串将被忽略。

  • startOfWeek 相同的是:

    • 指定:函数 $dateTrunc 使用 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值到两周

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

在示例中

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

  • $dateTruncorderDate字段截断为2 binSize week unit时间周期,在America/Los_Angeles timezone中,startOfWeek设置为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")
}
]

此示例使用 $dateTrunc$group 阶段,以截断糕点销售 orderDate 值到六个月,并返回 quantity 值的总和。

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

在示例中

  • $group_id 字段设置为 truncatedOrderDate 字段,以对 cakeSales 文档进行分组,并使用 $sum 返回每个分组的 quantity 值的总和。

  • $dateTruncorderDate 字段截断到 6 个月 binSize 单位 时间段。

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

本页内容