热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MongoDB操作手册CRUD更新update

修改记录概述MongoDB提供了update()方法用于更新记录。这个方法接受以下参数:一个更新条件的JSON对象用于匹配记录,一个更新操作JSON对象用于声明更新操作,和一个选项JSON对象声明查询条件,使用和查询一样的结构和语法。默认情况下,update()更新单

修改记录 概述 MongoDB提供了update()方法用于更新记录。这个方法接受以下参数: 一个更新条件的JSON对象用于匹配记录,一个更新操作JSON对象用于声明更新操作,和一个选项JSON对象 声明查询条件,使用和查询一样的结构和语法。 默认情况下,update()更新单

修改记录

概述 MongoDB提供了update()方法用于更新记录。这个方法接受以下参数:
一个更新条件的JSON对象用于匹配记录,一个更新操作JSON对象用于声明更新操作,和一个选项JSON对象
声明查询条件,使用和查询一样的结构和语法。
默认情况下,update()更新单条记录,若要更新多条记录, 请使用multi选项。
更新记录中的指定字段 用于更新某个字段的某个值,MongoDB提供了update操作符,比如$set。
在执行更新操作时,一些操作符回创建没有的字段,如$set。
测试数据:db.testData.insert({item:'MON2'});

1.使用update操作符来更新字段值

对于某条记录,其中item字段值为MNO2,使用$set操作符来更新它的category和details字段,使用$currentDate操作符来更新lastModified字段
db.testData.update(
{item:'MNO2'},
{
$set:{
category:'apparel',
details:{model:'14Q3',manufacturer:'XYZ Company'}
},
$currentDate:{lastModified:true}
}
);
这个更新操作返回包含着操作状态的WriteResult对象。
一个成功的更新操作返回如下结果:
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
nMatched总段表明匹配的记录数,nModified字段表明修改的记录数。

2.更新内嵌字段

使用"."操作符,并将这个属性用引号括起来。

例:更新内嵌的model的details字段

db.testData.update({item:'ABC1'},{$set:{'details.model':'14Q2'}});

3.更新多条记录

更新包含category,值为”clothing“的所有记录的category值为“apparel”,lastModified字段为当前时间
db.testData.update(
{category:'clothing'},
{
$set:{category:'apparel'},
$currentDate:{lastModified:true}
},
{multi:true}
)
替换记录 除_id字段外,替换一条记录的所有内容,需要将新的整个记录的对象作为update()方法的第二个参数传进来。
替换的记录可以与之前的记录有着不同的字段,由于_id字段是 不可变的,在替换记录中可以省略_id字段。如果非要包含该字段,必须是集合中存在的一个值。
例:替换item字段为BE10的记录。替换后新的记录将只包含_id字段和替换记录中的字段。
db.testData.update(
{ item: "BE10" },
{
item: "BE05",
stock: [ { size: "S", qty: 20 }, { size: "M", qty: 5 } ],
category: "apparel"
}
)
upsert选项

概述

默认情况下,如果update()方法中没有匹配记录,这个方法将不执行任何操作。

但是,如果声明upsert:true,在有匹配记录的时候将进行更新,没有匹配的时候将进行插入操作。

1.替换记录时使用upsert

当使用update操作来替换一条记录的时候声明upsert:true,如果没有匹配的记录,MongoDB将使用update中的 查询条件创建一条新的记录,然后使用update中的用于替换的记录来替换新创建的记录的除_id字段外的所有内容。
db.testData.update(
{ item: "TBD1" },
{
item: "TBD1",
details: { "model" : "14Q4", "manufacturer" : "ABC Company" },
stock: [ { "size" : "S", "qty" : 25 } ],
category: "houseware"
},
{ upsert: true }
)
结果:nUpserted“:1表明
WriteResult({
"nMatched" : 0,//没有匹配记录
"nUpserted" : 1,//插入了一条新的记录
"nModified" : 0,//没有更新记录
"_id" : ObjectId("53dbd684babeaec6342ed6c7")//新插入的记录的_id
})

2.更新记录时使用upsert

当使用update操作来更新一条记录的时候声明upsert:true,同上
db.testData.update(
{ item: "TBD2" },
{
$set: {
details: { "model" : "14Q3", "manufacturer" : "IJK Co." },
category: "houseware"
}
},
{ upsert: true }
)
推荐阅读
  • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • MongoDB用户验证auth的权限设置及角色说明
    本文介绍了MongoDB用户验证auth的权限设置,包括readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase、cluster相关的权限以及root权限等角色的说明和使用方法。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • 本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ... [详细]
  • SpringBoot整合SpringSecurity+JWT实现单点登录
    SpringBoot整合SpringSecurity+JWT实现单点登录,Go语言社区,Golang程序员人脉社 ... [详细]
  • step1.为mongodb添加admin管理员root@12.154.29.163:~#mongoMongoDBshellversionv3.4.2connectingto:mo ... [详细]
  • 一、前言在数据库中,慢查询日志通常是用来进行优化数据库,MySQL中存在慢查询,Mongodb中也是如此。在Mongo中的慢查询属于Mon ... [详细]
  • 1.淘宝模拟登录2.天猫商品数据爬虫3.爬取淘宝我已购买的宝贝数据4.每天不同时间段通过微信发消息提醒女友5.爬取5K分辨率超清唯美壁纸6.爬取豆瓣排行榜电影数据(含GUI界面版) ... [详细]
  • Abp+MongoDb改造默认的审计日志存储位置
    一、背景在实际项目的开发当中,使用AbpZero自带的审计日志功能写入效率比较低。其次审计日志数据量中后期十分庞大,不适合与业务数据存放在一起。所以我们可以重新实现A ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • IhaveconfiguredanactionforaremotenotificationwhenitarrivestomyiOsapp.Iwanttwodiff ... [详细]
  • Python字典推导式及循环列表生成字典方法
    本文介绍了Python中使用字典推导式和循环列表生成字典的方法,包括通过循环列表生成相应的字典,并给出了执行结果。详细讲解了代码实现过程。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
author-avatar
手机用户2502904705
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有