Docs 菜单
Docs 主页
/
MongoDB Manual
/ / /

$isoDayOfWeek(聚合)

在此页面上

  • 定义
  • 行为
  • 例子
$isoDayOfWeek

版本 3.4 中的新增功能

以 ISO 8601 格式返回工作日数字,范围为 1(星期一)到 7(星期日)。

$isoDayOfWeek 表达式采用以下 操作符表达式语法

{ $isoDayOfWeek: <dateExpression> }

参数可以是:

  • 可解析为日期时间戳对象标识符的表达式

  • 具有此格式的文档:

    { date: <dateExpression>, timezone: <tzExpression> }
    字段
    说明
    date
    应用操作符的日期。<dateExpression> 必须是解析为日期时间戳对象标识符的有效表达式
    timezone

    Optional. 操作结果的时区。 <tzExpression>必须是有效 表达式 string,可解析为格式为 Olson 时区标识符 的 或 UTC 偏移量 。如果未提供timezone ,则结果将显示在UTC中。

    format
    示例
    Olson Timezone Identifier
    "America/New_York"
    "Europe/London"
    "GMT"
    UTC Offset
    +/-[hh]:[mm], e.g. "+04:45"
    +/-[hh][mm], e.g. "-0530"
    +/-[hh], e.g. "+03"
例子
结果
{ $isoDayOfWeek: new Date("2016-01-01") }
5
{ $isoDayOfWeek: { date: new Date("Jan 7, 2003") } }
2
{ $isoDayOfWeek: {
date: new Date("August 14, 2011"),
timezone: "America/Chicago"
} }
7
{ $isoDayOfWeek: ISODate("1998-11-07T00:00:00Z") }
6
{ $isoDayOfWeek: {
date: ISODate("1998-11-07T00:00:00Z"),
timezone: "-0400"
} }
5
{ $isoDayOfWeek: "March 28, 1976" }
error
{ $isoDayOfWeek: Date("2016-01-01") }
error
{ $isoDayOfWeek: "2009-04-09" }
error

注意

$isoDayOfWeek 不能将字符串作为参数。

名为 birthdays 的集合包含以下文档:

{ "_id" : 1, "name" : "Betty", "birthday" : ISODate("1993-09-21T00:00:00Z") }
{ "_id" : 2, "name" : "Veronica", "birthday" : ISODate("1981-11-07T00:00:00Z") }

以下操作返回每个birthday字段的工作日编号。

db.dates.aggregate( [
{
$project: {
_id: 0,
name: "$name",
dayOfWeek: { $isoDayOfWeek: "$birthday" }
}
}
] )

操作返回以下结果:

{ "name" : "Betty", "dayOfWeek" : 2 }
{ "name" : "Veronica", "dayOfWeek" : 6 }

提示

另请参阅:

后退

$isNumber

在此页面上