MongoDB聚合运算符;$dateToString
$dateToString聚合运算符按用户指定的格式将日期对象转为字符串。
语法
{ $dateToString: {date: <dateExpression>,format: <formatString>,timezone: <tzExpression>,onNull: <expression>
} }
字段说明:
| 字段 | 是否必须 | 描述 |
|---|---|---|
date | 是 | <dateExpression>可以是日期、时间戳或对象Id表达式 |
format | 否 | 日期格式,<formatString>可以是任何字符串,包含0个或多个格式指示符 |
timezone | 否 | 执行操作的时区,<tzExpression>必须是能被解析为奥尔森时区标识符格式的字符串或UTC偏移量,如果timezone不指定,返回值显示为UTC |
onNull | 否 | 当date为空或缺失时的返回值。参数可以是任何有效的表达式。如果未指定$dateToString会在date为null或缺失时返回null。 |
使用
格式指示符
<formatString>格式指示符可以是下面的值:
| 指示符 | 描述 | 可能的值 |
|---|---|---|
| %b | 月份缩写(3个字符) | jan, feb, mar, apr, may, jun, jul, aug, sep, oct, nov, dec |
| %B | 完整月份 | january-december |
| %d | 一个月内的第几天(2个数字,0填充) | 01-31 |
| %G | ISO8601格式 年 | 0000-9999 |
| %H | 小时(2个数字,0填充,24小时时钟) | 00-23 |
| %j | 一年内的第几天(3个数字,0填充) | 001-366 |
| %L | 毫秒(3个数字,0填充) | 000=999 |
| %m | 月(2个数字,0填充) | 01-12 |
| %M | 分钟(2个数字,0填充) | 00-59 |
| %S | 秒(2个数字,0填充) | 00-60 |
| %u | ISO8601格式的一周内的第几天 | 1-7 |
| %U | 一年内的第几周(2个数字,0填充) | 00-53 |
| %V | ISO8601格式的一年内的第几周 | 1-53 |
| %w | 一周内的第几天(整数,0-Sunday,6-Saturday) | 0-6 |
| %Y | 年(4个数字,0填充) | 0000-9999 |
| %z | 时区与UTC的偏移量 | +/-[hh][mm] |
| %Z | 从 UTC 开始的分钟偏移量,用数字表示。例如,如果时区偏移(+/-[hhmm])为 +0445,则分钟偏移为+285。 | +/-mmm |
| %% | 百分比字符作为字面值 | % |
举例
集合sales有下面的文档:
{"_id" : 1,"item" : "abc","price" : 10,"quantity" : 2,"date" : ISODate("2014-01-01T08:15:39.736Z")
}
下面的聚合使用$dateToString返回date字段格式化后的字符串:
db.sales.aggregate([{$project: {yearMonthDayUTC: { $dateToString: { format: "%Y-%m-%d", date: "$date" } },timewithOffsetNY: { $dateToString: { format: "%H:%M:%S:%L%z", date: "$date", timezone: "America/New_York"} },timewithOffset430: { $dateToString: { format: "%H:%M:%S:%L%z", date: "$date", timezone: "+04:30" } },minutesOffsetNY: { $dateToString: { format: "%Z", date: "$date", timezone: "America/New_York" } },minutesOffset430: { $dateToString: { format: "%Z", date: "$date", timezone: "+04:30" } },abbreviated_month: { $dateToString: {format: "%b", date: "$date", timezone: "+04:30" } },full_month: { $dateToString: { format: "%B", date: "$date", timezone: "+04:30" } }}}]
)
执行的结果如下:
{"_id" : 1,"yearMonthDayUTC" : "2014-01-01","timewithOffsetNY" : "03:15:39:736-0500","timewithOffset430" : "12:45:39:736+0430","minutesOffsetNY" : "-300","minutesOffset430" : "270","abbreviated_month": "Jan","full_month": "January"
}
相关文章:
MongoDB聚合运算符;$dateToString
$dateToString聚合运算符按用户指定的格式将日期对象转为字符串。 语法 { $dateToString: {date: <dateExpression>,format: <formatString>,timezone: <tzExpression>,onNull: <expression> } }字段说明: 字段是否必须描述date是<da…...
【开源】SpringBoot框架开发教学资源共享平台
目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 课程档案模块2.3 课程资源模块2.4 课程作业模块2.5 课程评价模块 三、系统设计3.1 用例设计3.2 类图设计3.3 数据库设计3.3.1 课程档案表3.3.2 课程资源表3.3.3 课程作业表3.3.4 课程评价表 四、系统展…...
python基础——条件判断和循环【if,while,for,range】
📝前言: 这篇文章主要讲解一下条件判断语句if和循环语句while,for在python中需要注意的地方。 建议已有一定了解(对语句的执行逻辑清楚)的读者观看,如果对条件判断和循环的执行逻辑不太清楚,也可…...
Pytorch 复习总结 6
Pytorch 复习总结,仅供笔者使用,参考教材: 《动手学深度学习》Stanford University: Practical Machine Learning 本文主要内容为:Pytorch 计算机视觉。 本文先介绍了计算机视觉中两种常见的改进模型泛化性能的方法:…...
借助 Terraform 功能协调部署 CI/CD 流水线-Part 1
在当今快节奏的开发环境中,实现无缝、稳健的 CI/CD 流水线对于交付高质量软件至关重要。在本文中,我们将向您介绍使用 Bitbucket Pipeline、ArgoCD GitOps 和 AWS EKS 设置部署的步骤,所有步骤都将利用 Terraform 的强大功能进行编排。在Part…...
云原生基础知识:容器技术的历史
容器化的定义: 容器化是一种轻量级的虚拟化技术,将应用程序及其所有依赖项(包括运行时、系统工具、系统库等)打包到一个称为容器的单独单元中。容器提供了一种隔离的执行环境,使得应用程序可以在不同的环境中运行&…...
golang实现正向代理和反向代理
文章目录 正向代理反向代理区别与联系:总结代理服务器实现正向代理反向代理正向代理 正向代理是客户端代理,它位于客户端和目标服务器之间。它的作用是保护客户端的隐私和安全。 如我们现在想要访问谷歌,但是由于某些原因,无法直接访问到谷歌,我们可以通过连接一台代理服务…...
grpc四种数据流
grpc四种数据流 简介 1.简单模式 这种模式最为传统,即客户端发起一次请求,服务端响应一个数据,这和大家平时熟悉的rpc没什么区别,所以不在详细介绍 2.服务端数据流模式 这种模式是客户端发起一次请求,服务端返回一段连续的数据流。典型的例子是客户端向服务端发…...
SpringCloud-Alibaba-Nacos教程
SpringCloud-Alibaba-Nacos教程 下载地址 https://github.com/alibaba/nacos/releases/tag/2.2.3 直接进入bin包 运行cmd命令 startup.cmd -m standalone 运行成功后 进入nacos可视化页面 账号密码默认都是nacos http://localhost:8848/nacos 微服务入驻Nacos服务注册…...
bug_java
文章目录 1.创建Maven时: idea报错为:java:错误:不支持发行版本52. Springbot启动报错-类文件具有错误的版本 61.0, 应为 52.0 1.创建Maven时: idea报错为:java:错误:不支持发行版本…...
【目标检测】旋转目标检测DOTA格式转YOLO格式标注
准备DOTA格式数据集: dota_dataset -- images |----- train |----- val -- labels |----- train |----- train_original |----- val |----- val_original 修改class_mapping和图片格式: ultralytics/data/converter.py convert_dota_to_yolo_obb() 转换标…...
运动想象 (MI) 迁移学习系列 (3) : MSFT
运动想象迁移学习系列:MSFT 0. 引言1. 主要贡献2. 数据增强方法3. 基于度量的空间滤波转换器3.1 空间过滤3.2 脑电图ViT3.2.1 变压器编码器层3.2.2 基于度量的损失函数 4. 实验结果4.1 消融实验4.2 基线任务对比4.3 跨主体 5. 总结欢迎来稿 论文地址:https://www.s…...
NeRF模型NeRF模型
参考视频:https://www.youtube.com/watch?vHfJpQCBTqZs&ab_channelVision%26GraphicsSeminaratMIT NeRF模型的输入输出: 输入: (x, y, z): 一个三维空间坐标,代表场景中的一个位置点(θ, φ): 视线方向,θ表示与y轴的夹角,φ表示与x轴的夹角,用两个角度可以…...
python爬虫(4)
#前期先说明一下为啥爬虫需要学习数组的存储和处理,只是说在你后期接触到最简单的爬虫后有一个地方可以存放你的数据# 下面为大家带来一个我在做excel表整理时的代码以及上次代码的结果 上次代码的结果: 新的代码: import numpy as np im…...
递归神经网络 (RNN) 及其变体 LSTM (长短期记忆) 和 GRU (门控循环单元)
递归神经网络(RNN, Recurrent Neural Networks)是一类用于处理序列数据的神经网络,特别适合于时间序列数据、语音、文本等连续数据的处理。RNN之所以独特,是因为它们在模型内部维持一个隐藏状态,该状态理论上可以捕获到…...
Redis的HyperLogLog原理介绍
Redis 的 HyperLogLog 数据结构实现了一种基于概率的基数估算算法,用于在占用极小内存的情况下估算一个集合中不重复元素(唯一值)的数量。以下是 HyperLogLog 算法的基本原理: 哈希函数: HyperLogLog 使用一个强散列函…...
微信小程序开发系列(二十六)·小程序运行机制(启动、前后台状态、挂起、销毁)和小程序更新机制
目录 1. 小程序运行机制 1.1 启动 1.2 前台和后台状态 1.3 挂起 1.4 销毁 2. 小程序更新机制 1. 小程序运行机制 1.1 启动 小程序启动可以分为两种情况,一种是冷启动,一种是热启动。 冷启动:如果用户首次打开,或小…...
百度信息流
计划: 流量选择 - 四个维度: 百度信息流 ; 整合了百度APP、WAP、PC各频道信息流和内容详情页的流量资源,广告和信息流内容资讯穿插展现;适合所有产品呢 好看视频; 汇集海量优质的视频内容,通过智能推荐算法为用户推送最适合的视频广告,视频广告在列表页有声…...
JAVA后端开发面试基础知识(十)——设计模式
创建型模式 创建型模式的作用就是创建对象,说到创建一个对象,最熟悉的就是 new 一个对象,然后 set 相关属性。但是,在很多场景下,我们需要给客户端提供更加友好的创建对象的方式,尤其是那种我们定义了类&am…...
红帽认证知识储备-Linux安全
Linux安全 内置安全机制 常见的系统用的centos中用的是SELinux,ubuntu用的是AppArmor,deepin什么都没用 SELINUX 定义 SELinux 是一个 Linux 内核安全模块,它增强了系统的安全性,通过实施强制访问控制策略来限制程序和用户对系…...
Java虚拟机精讲【1.1】
1.2.4 Java虚拟机 Java 技术的核心就是 Java 虚拟机( JVM, Java Virtual Machine),因为所有的 Java 程序都运行在 Java 虚拟机内部。 JVM 之所以被称之为 VM,是因为它是由一组规范所定义出的抽象计算机。 JVM 的主要任务就是负责将字节码装载到其内部,解释/编译为对应平…...
2025届学术党必备的降AI率工具推荐
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 为了降低文本的 AIGC 率,得从语言自然度与结构差异性这两个关键要点着手。就语言…...
VB6老项目维护:MSHFlexGrid和MSFlexGrid控件选错了怎么办?手把手教你识别与替换
VB6老项目维护实战:MSHFlexGrid与MSFlexGrid控件的精准识别与无缝替换 接手VB6老项目时,最让人头疼的莫过于那些名字相似却功能迥异的控件。上周在客户现场就遇到一个典型案例:项目组花了三天时间调试一个"无法合并单元格"的问题&a…...
终极免费PCB查看器:5分钟掌握OpenBoardView,轻松破解电路板设计难题
终极免费PCB查看器:5分钟掌握OpenBoardView,轻松破解电路板设计难题 【免费下载链接】OpenBoardView View .brd files 项目地址: https://gitcode.com/gh_mirrors/op/OpenBoardView 你是否曾面对复杂的.brd电路板文件感到无从下手?或者…...
安全代码审查
安全代码审查:守护数字世界的基石 在数字化时代,软件已成为社会运转的核心载体,但随之而来的安全漏洞也带来了巨大风险。安全代码审查作为开发流程中的关键环节,能够从源头发现并修复潜在漏洞,避免数据泄露、系统瘫痪…...
10分钟掌握Fideo:免费开源直播录制软件的终极指南
10分钟掌握Fideo:免费开源直播录制软件的终极指南 【免费下载链接】fideo-live-record A convenient live broadcast recording software! Supports Tiktok, Youtube, Twitch, Bilibili, Bigo!(一款方便的直播录制软件! 支持tiktok, youtube, twitch, 抖音ÿ…...
008、新星:状态空间模型(SSM)基础——从经典控制论到结构化状态空间序列模型(S4)
从一次深夜调试说起 上周在部署一个实时传感器滤波算法时,我又翻出了那本快散架的《现代控制理论》。凌晨三点,盯着屏幕上不断发散的卡尔曼滤波状态协方差矩阵,我突然意识到——我们总在谈论模型的“状态”,但到底什么才是序列建模中真正有效的状态表示?这个问题,成了我…...
用Python和Astropy库,5分钟搞定天体方位角与俯仰角的实战计算(附完整代码)
用Python和Astropy库5分钟实现天体坐标自动化计算 深夜的天文台里,望远镜操作员小张正为明天的观测任务做准备。他需要在不同时段捕捉M31仙女座星系的清晰图像,但手动计算每个时刻的方位角和高度角让他头疼不已。直到同事推荐了Astropy这个Python天文学…...
ESP32开发板到手后,除了点灯还能干啥?从Hello World到连接天猫精灵的完整项目实战
ESP32开发板实战:从点灯到智能家居语音控制的全链路开发指南 刚拿到ESP32开发板时,大多数人的第一个项目往往是点亮LED——这确实是验证硬件工作的好方法。但这款售价不到50元的开发板,实际上隐藏着足以支撑完整物联网项目的强大能力。本文将…...
APK Installer完整指南:在Windows上轻松安装Android应用
APK Installer完整指南:在Windows上轻松安装Android应用 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 想在Windows电脑上直接运行Android应用吗ÿ…...
