Mongodb中一个小巧的数据更新命令$inc

学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第55篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。

inc是一个很小巧的命令。说它小巧,一个是因为短,只有三个字符。另一个是说它功能轻巧。在开发库存,电商类的应用时,往往遇到订单增加,库存减少的数据更新场景。使用inc命令,可以将订单增加,库存减少在同一个原子操作中完成。使得这样复杂的数据性一致操作,变得很轻巧。同时,官方文档给出的篇幅也很小。忙碌了一天,阅读文档时也顿觉轻巧。

定义

使用操作符$inc,按照用户指定的大小,增加或减少字段值

语法

使用$inc操作符需要遵照下面的语法。其中,amount正值表示向字段增加,复制表示减少。

复制代码
{ $inc: { <field1>: <amount1>, <field2>: <amount2>, ...}}

行为

从mongodb5.0开始,更新操作的顺序按照文档字段名的字母表顺序执行。带有数字名称的字段,按照数字顺序更新。

如下面的更新语句中, 字段"a.2"在"a.10"前更新。因为数字2排列在数字10前。

复制代码
{$set: { "a.2": <new value>, "a.10": <new value>}}

操作符$inc接受正值和负值。

当字段不存在是,操作符$inc添加字段并将字段设置为指定的数值。

使用$inc操作空值null时,Mongodb会报错。

单文档操作中使用$inc操作符修改数据的行为是一个原子操作。

mongodb 5.0版本以后,向$inc传入空表达式({ })时,mongodb不再抛出错误。空表达式不会修改字段值 ,也不会在oplog中,添加新的操作记录。

应用举例

创建一个products集合,并插入数据。

复制代码
db.products.insertOne(
    {
        _id: 1,
        sku: "abc123",
        quantity: 10,
        metrics: { orders: 2, ratings: 3.5}
    }
)

构建数据修改脚本,满足下面的数据更新要求

  • 将字段"metrics.orders"值增加1

  • 将字段值quantity减2

    db.products.updateOne(
    {sku: "abc123"},
    {$inc: {quantity: -2, "metrics.orders": 1}}
    )

查看更新结果

复制代码
db.products.find()
{
	"_id" : 1,
	"sku" : "abc123",
	"quantity" : 8,
	"metrics" : {
		"orders" : 3,
		"ratings" : 3.5
	}
}
相关推荐
科技小花2 分钟前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸4 分钟前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain6 分钟前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希43 分钟前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神1 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员1 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java1 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿1 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴1 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
YOU OU1 小时前
三大范式和E-R图
数据库