定义
$dateFromParts版本 3.6 中的新增功能。
根据日期的组成属性,构造并返回日期对象。
$dateFromParts表达式的语法如下:{ $dateFromParts : { 'year': <year>, 'month': <month>, 'day': <day>, 'hour': <hour>, 'minute': <minute>, 'second': <second>, 'millisecond': <ms>, 'timezone': <tzExpression> } } 您还可以使用以下语法以ISO 周日期格式指定所属日期字段:
{ $dateFromParts : { 'isoWeekYear': <year>, 'isoWeek': <week>, 'isoDayOfWeek': <day>, 'hour': <hour>, 'minute': <minute>, 'second': <second>, 'millisecond': <ms>, 'timezone': <tzExpression> } } $dateFromParts接受包含以下字段的文档:重要
构造
$dateFromParts输入文档时,您不能同时使用日历日期和 ISO 周日期字段。字段必需/可选说明year必填字段,前提是不使用
isoWeekYearisoWeekYear必填字段,前提是不使用
yearmonth可选。只能与
year一起使用。isoWeek可选。只能与
isoWeekYear一起使用。day可选。只能与
year一起使用。isoDayOfWeek可选。只能与
isoWeekYear一起使用。一周中的某一天(星期一
1- 星期日7)。可以是任何计算结果为数字的表达式。默认值为
1。值范围:
如果指定的数字超出此范围,1-7$dateFromParts则会将差值纳入日期计算。有关示例,请参阅值范围。hourOptional
minuteOptional
secondOptional
millisecondOptional
timezoneOptional
<timezone>可以是任何计算结果为字符串的表达式,其值为:Olson 时区标识符,例如
"Europe/London"或"America/New_York",或者UTC 偏移量,格式如下:
+/-[hh]:[mm],例如"+04:45",或+/-[hh][mm],例如"-0530",或+/-[hh], e.g."+03".
有关表达式的更多信息,请参阅表达式。
行为
数值范围
year 和 isoWeekYear 支持的值范围是 1-9999。
如果为 year、isoWeekYear 和 timezone 以外的字段指定的值超出有效范围,$dateFromParts 在计算日期时会加上或减去其他日期部分的差值。
值大于范围
请考虑以下 $dateFromParts 表达式,其中 month 字段值为 14,比最大值 12 个月(或 1 年)多 2 个月:
{ $dateFromParts: { 'year' : 2017, 'month' : 14, 'day': 1, 'hour' : 12 } }
该表达式通过将 year 增加 1 并将 month 设置为 2 来计算日期,返回:
ISODate("2018-02-01T12:00:00Z")
值小于范围
考虑以下 $dateFromParts 表达式,其中 month 字段值为0,比最小值 1 个月小 1 个月:
{ $dateFromParts: { 'year' : 2017, 'month' : 0, 'day': 1, 'hour' : 12 } }
该表达式通过将 year 减少 1 并将 month 设置为 12 来计算日期,返回:
ISODate("2016-12-01T12:00:00Z")
时区
在 <timezone> 字段中使用 Olson 时区标识符时,如果适用于指定的时区,MongoDB 会应用 DST 偏移量。
例如,考虑包含以下文档的 sales 集合:
{ "_id" : 1, "item" : "abc", "price" : 20, "quantity" : 5, "date" : ISODate("2017-05-20T10:24:51.303Z") }
以下聚合说明了 MongoDB 如何处理 Olson 时区标识符的 DST 偏移量。该示例使用 $hour 和 $minute 操作符返回 date 字段的相应部分:
db.sales.aggregate([ { $project: { "nycHour": { $hour: { date: "$date", timezone: "-05:00" } }, "nycMinute": { $minute: { date: "$date", timezone: "-05:00" } }, "gmtHour": { $hour: { date: "$date", timezone: "GMT" } }, "gmtMinute": { $minute: { date: "$date", timezone: "GMT" } }, "nycOlsonHour": { $hour: { date: "$date", timezone: "America/New_York" } }, "nycOlsonMinute": { $minute: { date: "$date", timezone: "America/New_York" } } } }])
操作返回以下结果:
{ "_id": 1, "nycHour" : 5, "nycMinute" : 24, "gmtHour" : 10, "gmtMinute" : 24, "nycOlsonHour" : 6, "nycOlsonMinute" : 24 }
例子
以下聚合使用 $dateFromParts 从提供的输入字段中构建三个日期对象:
db.sales.aggregate([ { $project: { date: { $dateFromParts: { 'year' : 2017, 'month' : 2, 'day': 8, 'hour' : 12 } }, date_iso: { $dateFromParts: { 'isoWeekYear' : 2017, 'isoWeek' : 6, 'isoDayOfWeek' : 3, 'hour' : 12 } }, date_timezone: { $dateFromParts: { 'year' : 2016, 'month' : 12, 'day' : 31, 'hour' : 23, 'minute' : 46, 'second' : 12, 'timezone' : 'America/New_York' } } } }])
操作返回以下结果:
{ "_id" : 1, "date" : ISODate("2017-02-08T12:00:00Z"), "date_iso" : ISODate("2017-02-08T12:00:00Z"), "date_timezone" : ISODate("2017-01-01T04:46:12Z") }