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

$isoDayOfWeek(聚合)

在此页面上

  • 定义
  • 行为
  • 例子
$isoDayOfWeek

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

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

{ $isoDayOfWeek: <dateExpression> }

参数可以是:

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

  • 具有此格式的文档:

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

    可选。 操作结果的时区。 <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 的集合包含以下文档:

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

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

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

操作返回以下结果:

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

提示

另请参阅:

后退

$isNumber

在此页面上