热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

MongoDB数据库的update操作讲解

之前没记录更新的操作,今天有空记录一下mongodbupdate的使用先看语法:db.collection.update(query,update,options)语法很简单,但是使用起来,要配合一些函数,就会复杂一些,解释一下query:条件限定,也就是需要更新行的条件,相当于SQL中where后面

之前没记录更新的操作,今天有空记录一下mongodb update的使用

先看语法:

db.collection.update(  )

语法很简单,但是使用起来,要配合一些函数,就会复杂一些,解释一下

query:条件限定,也就是需要更新行的条件,相当于SQL中where后面的条件判断

update:相当于SQL表中的set语句

options:这里需要注意的是mongodb的更新操作,默认只更新符合条件的第一行,如果要更新符合条件的所有行,需要指定multi为true,还有一个一个参数是upsert,意思是如果不存在符合query的记录,插入update的数据,默认是false不插入,可以指定true

 最简单的一个例子,大家看一下:

PRIMARY> db.test.save({id:1,"name":"hank"})
PRIMARY> db.test.find()
{ "_id" : ObjectId("50c055656b41f59a0235881b"), "id" : 1, "name" : "hank" }
PRIMARY> db.test.update({id:1},{"name":"dazuiba"})
PRIMARY> db.test.find()
{ "_id" : ObjectId("50c055656b41f59a0235881b"), "name" : "dazuiba" }

默认更新一行例子:

PRIMARY> db.test.find()
{ "_id" : ObjectId("50c056876b41f59a0235881c"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c056886b41f59a0235881d"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c056896b41f59a0235881e"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c0568a6b41f59a0235881f"), "id" : 1, "name" : "hank" }
PRIMARY>  db.test.update({id:1},{"name":"dazuiba"})
PRIMARY>  db.test.find()
{ "_id" : ObjectId("50c056876b41f59a0235881c"), "name" : "dazuiba" }
{ "_id" : ObjectId("50c056886b41f59a0235881d"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c056896b41f59a0235881e"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c0568a6b41f59a0235881f"), "id" : 1, "name" : "hank" }

更新所有符合条件的行:

PRIMARY> db.test.find()
{ "_id" : ObjectId("50c056e46b41f59a02358820"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c056e56b41f59a02358821"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c056e66b41f59a02358822"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c056e86b41f59a02358823"), "id" : 1, "name" : "hank" }
PRIMARY> db.test.update({id:1},{"name":"dazuiba"},false,true)   --报错,大家注意一下这里,需要$相关的操作
multi update only works with $ operators
PRIMARY> db.test.update({id:1},{$set:{"name":"dazuiba"}},false,true)
PRIMARY> db.test.find()
{ "_id" : ObjectId("50c056e46b41f59a02358820"), "id" : 1, "name" : "dazuiba" }
{ "_id" : ObjectId("50c056e56b41f59a02358821"), "id" : 1, "name" : "dazuiba" }
{ "_id" : ObjectId("50c056e66b41f59a02358822"), "id" : 1, "name" : "dazuiba" }
{ "_id" : ObjectId("50c056e86b41f59a02358823"), "id" : 1, "name" : "dazuiba" }

更新不存在的行,如果不存在,那么插入进去:

PRIMARY> db.test.find()
{ "_id" : ObjectId("50c058256b41f59a02358828"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c058266b41f59a02358829"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c058266b41f59a0235882a"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c058276b41f59a0235882b"), "id" : 1, "name" : "hank" }
PRIMARY> db.test.update({id:2},{$set:{"name":"dazuiba"}},true,false)
PRIMARY> db.test.find()
{ "_id" : ObjectId("50c058256b41f59a02358828"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c058266b41f59a02358829"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c058266b41f59a0235882a"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c058276b41f59a0235882b"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c05840638c411993e87a5c"), "id" : 2, "name" : "dazuiba" }

只要理解了2个参数意思,灵活使用即可,以下是几个例子

PRIMARY> db.test.find()
{ "_id" : ObjectId("50c0589e6b41f59a0235882c"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c058a06b41f59a0235882d"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c058a16b41f59a0235882e"), "id" : 1, "name" : "hank" }
{ "_id" : ObjectId("50c058a16b41f59a0235882f"), "id" : 1, "name" : "hank" }
PRIMARY> db.test.update({id:1},{$set:{"name":"dazuiba"}},true,true)
PRIMARY> db.test.find()
{ "_id" : ObjectId("50c0589e6b41f59a0235882c"), "id" : 1, "name" : "dazuiba" }
{ "_id" : ObjectId("50c058a06b41f59a0235882d"), "id" : 1, "name" : "dazuiba" }
{ "_id" : ObjectId("50c058a16b41f59a0235882e"), "id" : 1, "name" : "dazuiba" }
{ "_id" : ObjectId("50c058a16b41f59a0235882f"), "id" : 1, "name" : "dazuiba" }
PRIMARY> db.test.update({id:2},{$set:{"name":"hank"}},true,true)
PRIMARY>  db.test.find()
{ "_id" : ObjectId("50c0589e6b41f59a0235882c"), "id" : 1, "name" : "dazuiba" }
{ "_id" : ObjectId("50c058a06b41f59a0235882d"), "id" : 1, "name" : "dazuiba" }
{ "_id" : ObjectId("50c058a16b41f59a0235882e"), "id" : 1, "name" : "dazuiba" }
{ "_id" : ObjectId("50c058a16b41f59a0235882f"), "id" : 1, "name" : "dazuiba" }
{ "_id" : ObjectId("50c058ea638c411993e87a5d"), "id" : 2, "name" : "hank" }

$相关操作下一次介绍


推荐阅读
  • MongoDB核心概念详解
    本文介绍了NoSQL数据库的概念及其应用场景,重点解析了MongoDB的基本特性、数据结构以及常用操作。MongoDB是一个高性能、高可用且易于扩展的文档数据库系统。 ... [详细]
  • 七大策略降低云上MySQL成本
    在全球经济放缓和通胀压力下,降低云环境中MySQL数据库的运行成本成为企业关注的重点。本文提供了一系列实用技巧,旨在帮助企业有效控制成本,同时保持高效运作。 ... [详细]
  • 在Android应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ... [详细]
  • 在中标麒麟操作系统上部署达梦数据库及导入SQL文件
    本文档详细介绍了如何在中标麒麟操作系统上安装达梦数据库,并提供了导入SQL文件的具体步骤。首先,检查系统的发行版和内核版本,接着创建必要的用户和用户组,规划数据库安装路径,挂载安装介质,调整系统限制以确保数据库的正常运行,最后通过图形界面完成数据库的安装。 ... [详细]
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • 本文介绍了如何通过安装 sqlacodegen 和 pymysql 来根据现有的 MySQL 数据库自动生成 ORM 的模型文件(model.py)。此方法适用于需要快速搭建项目模型层的情况。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文详细介绍了Oracle 11g中的创建表空间的方法,以及如何设置客户端和服务端的基本配置,包括用户管理、环境变量配置等。 ... [详细]
  • Maven + Spring + MyBatis + MySQL 环境搭建与实例解析
    本文详细介绍如何使用MySQL数据库进行环境搭建,包括创建数据库表并插入示例数据。随后,逐步指导如何配置Maven项目,整合Spring框架与MyBatis,实现高效的数据访问。 ... [详细]
  • 探讨在使用 PL/SQL Developer 12.0 的数据生成器时遇到的中文乱码问题及其解决方案。 ... [详细]
  • 软件测试行业深度解析:迈向高薪的必经之路
    本文深入探讨了软件测试行业的发展现状及未来趋势,旨在帮助有志于在该领域取得高薪的技术人员明确职业方向和发展路径。 ... [详细]
  • 本文介绍了一种使用SQL Server存储过程来实现基于单一条件的高效分页查询的方法。通过示例代码,详细说明了如何构建和执行这种分页查询。 ... [详细]
  • 如何在Django框架中实现对象关系映射(ORM)
    本文介绍了Django框架中对象关系映射(ORM)的实现方式,通过ORM,开发者可以通过定义模型类来间接操作数据库表,从而简化数据库操作流程,提高开发效率。 ... [详细]
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • 本文探讨了实现类似滴滴出行的实时位置推送的技术方案,包括LBS服务和消息推送服务的架构设计。 ... [详细]
author-avatar
mobiledu2502870557
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有