位置: 编程技术 - 正文

MongoDB中文档的更新操作示例详解(mongodb document)

编辑:rootadmin

推荐整理分享MongoDB中文档的更新操作示例详解(mongodb document),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mongodb bi,mongodb项目使用说明,mongodb基本操作,mongodb 文档,mongodb中文手册,mongodb 文档,mongodb中文手册,mongodb docs,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

在MongoDB中,更新单个doc的操作是原子性的。默认情况下,如果一个update操作更新多个doc,那么对每个doc的更新是原子性的,但是对整个update 操作而言,不是原子性的,可能存在前面的doc更新成功,而后面的doc更新失败的情况。由于更新单个doc的操作是原子性的,如果两个更新同时发生,那么一个更新操作会阻塞另外一个,doc的最终结果值是由时间靠后的更新操作决定的。

我们在前面的文章中提到过文档的基本的增删改查操作,MongoDB中提供的增删改查的语法非常丰富,不清楚的朋友们可以参考这篇文章:

$push可以向已有数组末尾追加元素,要是不存在就创建一个数组,还是以我们的上面的book为例,假设book有一个字段为comments,是一个数组,表示对这个book的评论,我们可以使用如下命令添加一条评论:

此时不存在comments字段,系统会自动帮我们创建该字段,结果如下:

此时我们可以追加评论,如下:

结果如下:

如果想一次添加3条评论,可以结合$each一起来使用,如下:

结果如下:

我们可以使用$slice来固定数组的长度,假设我固定数组的长度为5,如果数组中的元素不足5个,则全部保留,如果数组中的元素超过5个,则只会保留最新的5个,如下:

注意:$slice的值为负数,运行结果如下:

我们还可以在清理之前使用$sort对数据先进行排序,然后再清理比如我有一个class文档,如下:

现在向这个文档中插入student,每个student有姓名和成绩,然后按照成绩降序排列,只要前5条数据,如下:

$sort的取值为-1和1,-1表示降序,1表示升序。

上面的命令执行两次之后(即插入两次),结果如下:

$slice和$sort不能只和$push一起使用,还要加上$each。

MongoDB中文档的更新操作示例详解(mongodb document)

$addToSet

我们可以在插入的时候使用$addToSet,表示要插入的值如果存在则不插入,否则插入,如下:

上面的命令执行多次之后,发现只成功插入了一条数据。也可以将$addToSet和$each结合起来使用,如下:

$pop

$pop可以用来删除数组中的数据,如下:

1表示从comments数组的末尾删除一条数据,-1表示从comments数组的开头删除一条数据。

$pull

使用$pull我们可以按条件删除数组中的某个元素,如下:

表示删除数组中值为的数据。

$

既然是数组,我们当然可以通过下标来访问,如下一行操作表示将下标为0的(第一个comments)comments修改为:

可是有的时候我并不知道我要修改的数据处于数组中的什么位置,这个时候可以使用$符号来解决:

查询条件查出来的下标,$符号就代码这个下标,然后通过$符号就能将之修改。

save

save是shell中的一个函数,接收一个参数,这个参数就是文档,如果文档中有_id参数save会执行更新操作,否则执行插入操作,使用save操作我们可以方便的完成一些更新操作。

类似于如下命令则表示一个插入操作(因为没有_id):

好了,MongoDB的更新操作我们就先介绍这么多,有问题欢迎留言讨论。

参考资料:

1.《MongoDB权威指南第2版》

总结

标签: mongodb document

本文链接地址:https://www.jiuchutong.com/biancheng/312089.html 转载请保留说明!

上一篇:Java操作mongodb的模糊查询和精确查询(java操作mongodb数据库)

下一篇:MongoDB用Mongoose得到的对象不能增加属性完美解决方法(两种)(mongodb morphia)

  • 福建国税网上办税平台登录
  • 出口抵减内销产品应纳税额为什么在借方
  • 增值税申报表如何打印
  • 耕地占用税的税目
  • 允许抵扣的进项税额分为哪几种情况
  • 公司购买新车购置税是否可以抵扣呢
  • 收据四联分别叫什么
  • 企业中征码全称
  • 银行付款回单怎么看
  • 其他应付款长期挂账违反什么规定
  • 记账凭证的附件包括哪些
  • 从基本存款账户之外的银行结算账户转账存入
  • 如何理解发票开具加税点的说法?
  • 本月计错多发的工资可以不交个税
  • 增值税附加税怎么报税
  • 腾讯计算机系统扣费15元怎么查
  • 公司注销了之后银行账户还能用吗
  • 外地项目不预缴税款
  • abs付款是现金吗
  • 注册中的商标转让
  • 工商年报纳税总额怎么填写才正确
  • linux设置用户密码
  • win10电脑防火墙如何关闭
  • 企业员工个人所得税申报流程
  • 明细分类帐户
  • linux中的大于号什么意思
  • 未缴纳社保可以直接走人吗
  • wordpress创建
  • 红字发票冲减的是当月收入吗
  • 饭店的手撕发票可以报销吗
  • 代垫运费的增值税可以抵扣吗
  • yolo s
  • php异常处理方法
  • 命令行mkdir创建文件夹
  • ps怎么把图片套入样机快捷键
  • 加计扣除内容
  • 自由会计服务类工作者
  • MySQL中用通用查询日志找出查询次数最多的语句的教程
  • python os.path.join()函数的使用
  • 业务招待费汇算清缴怎么填表
  • 公司入股方式有哪几种
  • 小微企业免征的增值税怎么做账
  • 工资发放凭证原件指什么意思
  • 物业公司的会计好干吗
  • 差额开票和全额开票
  • 存货报废进项税额需要转出吗
  • 管理人员工资结构
  • 以资抵债如何实现债权和物权的转
  • 固定资产清理在贷方怎么结转
  • 增值税发票打印机怎么调整打印位置
  • 可供出售金融资产属于什么科目
  • 理财产品产生的收益会成为本金吗为什么
  • 小规模公司购买成本票严重吗
  • 外汇申报国家代码表
  • 年初建账考虑要点业务流程是否变化
  • 无形资产的商誉是什么
  • sqlserver批量删除数据
  • win7系统一键还原方法
  • windows自动操作软件
  • ubuntu12.04系统怎么安装PPS播放器?
  • win7开启远程设置
  • 2007皖价服
  • windows 8 key
  • linux配置ssh服务器 用户名
  • 基于jquery的表单验证插件
  • Cocos2dx -lua QuickXDev拓展
  • JavaScript Math.ceil() 函数使用介绍
  • 简述ajax
  • Android startActivities()的使用
  • 批量压缩命令
  • jquery中的动画吗,是怎样用的
  • jquery form validate
  • android学什么
  • 餐饮服务需要交印花税吗?
  • 交错了税可以退吗
  • 河南12306区号
  • 保险代理人非公司员工
  • 4s店买车需要驾驶证吗
  • 百旺税控盘电话服务热线
  • 90平房子税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设