# 更新数据

在本节中我们还是沿用 读取数据 章节中使用的数据。

更新数据主要有两个方法:

API 说明
update 局部更新一个或多个记录。
set 替换更新一个记录。

# 局部更新

使用 update 方法可以局部更新一个记录或一个集合中的记录,局部更新意味着只有指定的字段会得到更新,其他字段不受影响。

例如我们可以用以下代码将一个待办事项置为已完成:

    除了用指定值更新字段外,数据库 API 还提供了一系列的更新指令用于执行更复杂的更新操作,更新指令可以通过 db.command 取得:

    更新指令 说明
    set 设置字段为指定值
    remove 删除字段
    inc 原子自增字段值
    mul 原子自乘字段值
    push 如字段值为数组,往数组尾部增加指定值
    pop 如字段值为数组,从数组尾部删除一个元素
    shift 如字段值为数组,从数组头部删除一个元素
    unshift 如字段值为数组,往数组头部增加指定值

    例如我们可以将一个待办事项的进度+10%。示例代码如下:

      inc 指令而不是取出值、加 10 再写进去的好处在于这个写操作是个原子操作,不会受到并发写的影响,例如同时有两名用户 A 和 B 取了同一个字段值,然后分别加上 10 和 20 再写进数据库,那么这个字段最终结果会是加了 20 而不是 30。如果使用 inc 指令则不会有这个问题。

      如果字段是个数组,那么我们可以使用 pushpopshiftunshift 对数组进行原子更新操作,例如给一条待办事项加多一个标签:

        更完整详细的更新指令可以参考 数据库文档

        # 替换更新

        如果需要替换更新一条记录,可以在记录上使用 set 方法,替换更新意味着用传入的对象替换指定的记录:

          如果指定 ID 的记录不存在,则会自动创建该记录,该记录将拥有指定的 ID。

          # 批量更新

          通过 where().update() 可以找到符合查询条件的文档列表,并进行更新(服务端 node-sdk 同时支持只更新找到的第一条文档)