[小程序云开发]解决并发下数据不一致问题

常见于抢购、人数限制等场景。
1. 利用原子操作符 借助原子操作符,可以实现。原子操作符包括:

  • inc
  • mul
  • addToSet
例:
const _ = db.command; let res = await db.collection('my_collection').where({ _id: id, limit: _.lt(10) }).update({ data: { limit: _.inc(1) } })

通过使用原子操作符inc,避免并发写的影响。
小程序云开发文档是这样描述的:
用 inc 指令而不是取出值、加 10 再写进去的好处在于这个写操作是个原子操作,不会受到并发写的影响,比如同时有两名用户 A 和 B 取了同一个字段值,然后分别加上 10 和 20 再写进数据库,那么这个字段最终结果会是加了 20 而不是 30。如果使用 inc 指令则不会有这个问题。
( https://developers.weixin.qq....)
2. 利用事务 【[小程序云开发]解决并发下数据不一致问题】直接参考小程序云开发文档就好。
需要注意的是,事务中不支持批量操作,仅支持单记录操作。

    推荐阅读