MongoDB 文档更新update

无论是关系型数据库还是非关系型数据库,数据插入数据库,都会有更新的需求。与其他数据库数据一致,mongodb提供update方法来更新数据库中的数据。

更新方法

mongodb为不同的场景提供更新方法

  • db.collection.updateOne()更新一条数据
  • db.collection.updateMany()更新多条数据
  • db.collection.replaceOne(),替换文档中除了_id字段外的所有字段。

还有一些和数据查找结合使用的方法

  • db.collection.findOneAndReplace()
  • db.collection.findOneAndUpdate()
  • db.collection.findAndModify()
  • db.collection.bulkWrite()

语法

db.collection.updateOne(
  {},//filter
  { //update object
    <update operator>: {<field1>:<value1>, ...},
    <update operator>: {<field2>:<value2>, ...}
  },
  {} //options
)

db.collection.updateMany(
  {},//filter
  { //update object
    <update operator>: {<field1>:<value1>, ...},
    <update operator>: {<field2>:<value2>, ...}
  },
  {} //options
)

db.collection.replaceOne(
  {},//filter
  { //update object
    <update operator>: {<field1>:<value1>, ...},
    <update operator>: {<field2>:<value2>, ...}
  },
  {} //options
)

其中,filter用来查询出需要更新的数据,update object定义了需要更新的字段和目标值。update object支持数据定义聚合管道来更新数据。options, 定义upsert, writeconcern, collation, arrayFilter, hint等参数。

行为

原子性

Mongodb进行数据更新时,对单个文档的更新时原子性的。当使用updateMany方法更新多条数据时,updateMany操作不是原子性的,Mongodb会将updateMany中多条更新转换成逐条数据更新,而这种数据逐条更新操作,是原子性的。

_id字段

Mongodb中文档的_id字段是不可变的,不可以对_id字段进行更新。

字段顺序

写操作中,Mongodb默认保留文档插入式字段的顺序,但下面两种情况除外

  1. _id字段排在第一位
  2. 包含字段重新命名操作的数据更新,会触发字段顺序的重新排列。

Upsert选项

在操作updateOne(), updateMany(), replaceOne()方法中,指定upsert:true时,如果没有文档符合指定的过滤条件,数据更新操作会创建一个新的文档并插入到集合中。如果当前集合中有符合过滤条件的文档,则这些文档。

写入策略

Mongodb支持用户在options中自定义写入策略。

应用举例

构建测试集合

db.inventory.insertMany([
   { item: "canvas", qty: 100, size: { h: 28, w: 35.5, uom: "cm" }, status: "A" },
   { item: "journal", qty: 25, size: { h: 14, w: 21, uom: "cm" }, status: "A" },
   { item: "mat", qty: 85, size: { h: 27.9, w: 35.5, uom: "cm" }, status: "A" },
   { item: "mousepad", qty: 25, size: { h: 19, w: 22.85, uom: "cm" }, status: "P" },
   { item: "notebook", qty: 50, size: { h: 8.5, w: 11, uom: "in" }, status: "P" },
   { item: "paper", qty: 100, size: { h: 8.5, w: 11, uom: "in" }, status: "D" },
   { item: "planner", qty: 75, size: { h: 22.85, w: 30, uom: "cm" }, status: "D" },
   { item: "postcard", qty: 45, size: { h: 10, w: 15.25, uom: "cm" }, status: "A" },
   { item: "sketchbook", qty: 80, size: { h: 14, w: 21, uom: "cm" }, status: "A" },
   { item: "sketch pad", qty: 95, size: { h: 22.85, w: 30.5, uom: "cm" }, status: "A" }
])

更新{item:"paper"}的数据,即使可以找出多条文档, updateOne也只更新一条。默认按照数据插入时间排序。

db.inventory.updateOne(
    { item: "paper"},
    {
        $set: {'size.uom': "cm", status: "p"},
        $currentDate: {lastModified: true}
    }
)

使用set,更新字段'size.uom'和字段status的值。同时,使用currentDate,将lastModified字段更新到当前时间。如果字段lastModified不存在,则添加该字段。

更新多个文档数据

db.inventory.updateMany(
    {"qty": { $lt: 50}},
    {
        $set: {"size.uom": "in", status: "p"},
        $currentDate: {lastModified: true}
    }
)

替换一个文档

db.inventory.replaceOne(
    { item: "paper"},
    { item: "paper", instock:[{warehouse: "A", qty: 60}, {warehouse: "B", qty: 40}]}
    )

Mongodb支持替换文档中除了_id字段外的所有字段。更新后的文档字段,可以与源文档的字段不同。使用replaceOne时,用来替换的新文档中,必须由键值对构成,不可以包含update操作符和表达式。

相关推荐
林犀居士9 分钟前
H2数据库在单元测试中的应用
数据库·单元测试·h2·内存数据库
周周写不完的代码3 小时前
mysql -> 达梦数据迁移(mbp大小写问题兼容)
数据库·mysql·达梦
MiniFlyZt7 小时前
省市区三级联动(后端)
数据库·spring boot
背太阳的牧羊人7 小时前
用于与多个数据库聊天的智能 SQL 代理问答和 RAG 系统(2) —— 从 PDF 文档生成矢量数据库 (VectorDB),然后存储文本的嵌入向量
数据库·人工智能·sql·langchain·pdf
zhangxueyi8 小时前
MySQL之企业面试题:InnoDB存储引擎组成部分、作用
java·数据库·mysql·面试·innodb
代码代码快快显灵8 小时前
Redis 优化秒杀(异步秒杀)
数据库·redis·缓存
极客先躯8 小时前
Redis 安装与配置指南
数据库·redis·数据验证·安装说明·编译和安装·redis 集群配置·查看集群
YaenLi8 小时前
MySQL 安装部署
linux·数据库·mysql
乄北城以北乀9 小时前
一.MySQL程序简介
数据库·mysql
炭烤毛蛋9 小时前
Ubuntu 磁盘修复
linux·数据库·ubuntu