当前位置: 首页 > news >正文

深圳网站制作品牌祥奔科技重庆网站制作公司

深圳网站制作品牌祥奔科技,重庆网站制作公司,茂名网站开发公司推荐,广州网站建设公司招聘学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第54篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。 本文基于Mongodb的官方文档,整理了Mongodb字段更新操作符$currentDate的定义&#xff…

学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第54篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。

本文基于Mongodb的官方文档,整理了Mongodb字段更新操作符$currentDate的定义,语法,行为和操作用例,以供参考。

定义

Mongodb支持使用操作符$currentDate更新字段为当前时间。默认更新成Date类型的时间。但也支持将字段更新成为timestamp. 当字段不存在时,向更新的文档中添加字段并更新成当前时间。

语法

数据库操作人员在UPDATE语句中,通过下面的语法将字段更新成当前时间

{$currentDate: {<field1>: <typeSpecification1>, ...}}

其中<typeSpecification>可以使用下面中的任意一种形式:

  • 使用布尔类型的true,将指定的字段设置为当前时间。
  • 指定当前时间类型的文档,{$type: "timestamp"}或{$type: "date"}.其中$type类型中指定的字符串是大小写敏感的,并且只接受小写类型的字符串。

当指定的字段名称是嵌入式文档或位于数组当中时,需要使用点操作符('.')

行为

从mongodb5.0开始,更新操作的顺序按照文档字段名的字母表顺序执行。带有数字名称的字段,按照数字顺序更新。

如下面的更新语句中, 字段"a.2"在"a.10"前更新。因为数字2排列在数字10前。

{$set: { "a.2": <new value>, "a.10": <new value>}}

使用$currentDate更新字段时 ,获取到的时间是$currentDate的执行时间。

如果字段不存在 ,$currentDate向文档中添加该字段。

mongodb 5.0版本以后,向$currentDate传入空表达式({ })时,mongodb不再抛出错误。空表达式不会修改字段值 ,也不会在oplog中,添加新的操作记录。

应用举例

创建一个customers集合并插入一条数据。

db.customers.insertOne({_id: 1, status: "a", lastModified: ISODate("2013-10-02T01:11:18.965Z")
})

构建一条数据更新语句,要求添加cancellation文档字段,包含字段date和reason。其中,date字段是脚本执行时间。 修改字段status的值为"D"。同时将lastModified更新为脚本执行时间。

db.customers.updateOne({_id: 1},{$currentDate: {lastModified: true,"cancellation.date":{ $type: "timestamp"}},$set:  {"cancellation.reason": "user request",status: "D"}}
)

查看更新结果

db.customers.find()
{"_id" : 1,"status" : "D","lastModified" : ISODate("2024-04-01T15:57:28.663+08:00"),"cancellation" : {"date" : Timestamp(1711957959, 1),"reason" : "user request"}
}

自mongodb 4.2版本开始,也支持使用聚合操作来更新数据。其中$$CLUSTER_TIME只在复制集和分片集中使用。$$NOW和$$CLUSTER_TIME在聚合管道中返回相同的时间戳。

db.customers.updateOne({ _id: 1 },[{$set: {lastModified: "$$NOW", cancellation:  {date: "$$CLUSTER_TIME", reason: "user request"}, status: "D"}}        ]
)

http://www.yayakq.cn/news/907808/

相关文章:

  • wordpress查询分页插件百度搜索引擎优化案例
  • xp做网站通辽做网站制作
  • 网站开发流程ppt包就业的培训机构
  • 搬瓦工如何搭建做网站电商网站开发人员人数
  • seo站群优化技术电商培训网站
  • 数据分析案例网站如何制作公司宣传片
  • 丘受网站谁做的网球吧如何打死网站
  • 广州哪个公司做网站用vs网站开发
  • 获取网站访客信息桓台网站建设
  • app软件开发就是网站开发吗集客营销软件官方网站
  • 陇西做网站的广告店软文营销广告案例
  • 平面设计网站首页深圳在线问诊平台
  • 英语培训东莞网站建设资源分享网站怎么做
  • 济南网络安全公司怎么做优化网站排名
  • 门户网站php源码运城购物网站开发设计
  • 医疗企业网站模板python培训机构
  • 正规网站设计制作公司国家重点项目建设库网站
  • 电商网站搭建网站开发岗位简介
  • 酒水食品做的好网站济宁哪里做网站最便宜
  • 郑州市住房和城乡建设厅网站廊坊百度推广排名优化
  • 网站建设wordpress比较太原网站开发哪家好
  • 信用 网站 建设方案建立网站心得
  • 内网站做映射8个页面的网站怎么做
  • 报网站开发培训班佛山网站推广软件
  • 更改wordpress登陆页面logo广州四楚seo顾问
  • 化工网站开发百度搜索大数据怎么查
  • 苏州吴中网站建设做网站意义和目的
  • 广州建站平台哪家好长沙景点门票价格表
  • 网站建设网络拓扑ios开发教程
  • 织梦dedecms网站简略标题shorttitle的使用方法网络技术专业学什么