MongoDB聚合运算符:$isoWeek

文章目录

$isoWeek聚合运算符返回ISO 8601格式的周数,范围从1到53。周数从1 开始,表示包含一年中第一个星期四的周(星期一到星期日)。

语法

js 复制代码
{ $isoWeek: <dateExpression> }
  • <dateExpression>为可被解析为Date、Timestamp或ObjectID的表达式
  • <dateExpression>也可以是一个文档{ date: <dateExpression>, timezone: <tzExpression> }
    • date是可以被解析为Date、Timestamp或ObjectID的表达式
    • timezone可选,操作结果的时区,如果未提供时区,结果将以UTC格式显示。

使用

下面通过示例对使用规则进行说明:

例1

js 复制代码
{ $isoWeek: { date: new Date("Jan 4, 2016") } }

结果:1

例2

js 复制代码
{ $isoWeek: new Date("2016-01-01") }

结果:53

例3

js 复制代码
{ $isoWeek: {
    date: new Date("August 14, 2011"),
    timezone: "America/Chicago"
} }

结果:32

例4

js 复制代码
{ $isoWeek: ISODate("1998-11-02T00:00:00Z") }

结果:45

例5

js 复制代码
{ $isoWeek: {
    date: ISODate("1998-11-02T00:00:00Z"),
    timezone: "-0500"
} }

结果:44

例6

js 复制代码
{ $isoWeek: "March 28, 1976" }

结果:error

例7

js 复制代码
{ $isoWeek: Date("2016-01-01") }

结果:error

例8

js 复制代码
{ $isoWeek: "2009-04-09" }

结果:error

举例

deliveries集合有下面的文档:

json 复制代码
{ "_id" : 1, "date" : ISODate("2006-10-24T00:00:00Z"), "city" : "Boston" }
{ "_id" : 2, "date" : ISODate("2011-08-18T00:00:00Z"), "city" : "Detroit" }

以下操作返回date字段的星期编号:

js 复制代码
db.deliveries.aggregate( [
  {
    $project: {
      _id: 0,
      city: "$city",
      weekNumber: { $isoWeek: "$date" }
    }
  }
] )

操作返回下面的结果:

json 复制代码
{ "city" : "Boston", "weekNumber" : 43 }
{ "city" : "Detroit", "weekNumber" : 33 }
相关推荐
zhz52141 小时前
从PostgreSQL到人大金仓(KingBase)数据库迁移实战:Spring Boot项目完整迁移指南
数据库·spring boot·postgresql
万行1 小时前
点评项目(Redis中间件)&第一部分Redis基础
java·数据库·redis·缓存·中间件
SelectDB1 小时前
Apache Doris 登顶 RTABench —— 实时分析领域的性能王者
数据库·数据分析·开源
用户6279947182621 小时前
南大通用GBase 8a加载常见错误原因
数据库
咸甜适中1 小时前
rust语言(1.88.0)sqlite数据库rusqlite库(0.37.0)学习笔记
数据库·rust·sqlite·rusqlite
Jasonakeke1 小时前
【重学 MySQL】九十二、 MySQL8 密码强度评估与配置指南
android·数据库·mysql
heath ceTide2 小时前
第二章从事件驱动到信号
数据库·系统架构
StarRocks_labs2 小时前
欧洲数字化养殖平台 Herdwatch 借力 Iceberg + StarRocks 提升分析能力
数据库·starrocks·iceberg·湖仓一体架构·herdwatch
TDengine (老段)3 小时前
TDengine IDMP 5 个实测场景让监控变简单
大数据·数据库·物联网·ai·时序数据库·tdengine·涛思数据
叫我阿柒啊3 小时前
Java全栈开发面试实战:从基础到复杂场景的深度解析
java·数据库·spring boot·面试·vue·测试·全栈开发