学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第72篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。如果您认为我的文章对您有帮助或者解决您的问题,欢迎在文章下面点个赞,或者关注威赞。谢谢。
本篇文章,我们聊聊在mongodb数组更新的操作符$position. mongodb提供$position操作符,满足了数组更新中在指定位置插入指定元素的需求。不过mongodb在使用这个操作符时也有一些限制。本文就针对$position的使用和限制做详细说明。
定义
$position操作符,指定了数组更新使用$push时,插入元素的位置 。当用户向数组元素插入数据,不指定位置时,默认将元素插入到数组结尾。$position操作符,一定要和$each操作符搭配使用,按照下面的形式。
{
$push: {
<field>: {
$each: [<value1>, <value2>, ...],
$position: <num>
}
}
}
其中<num>指定了数组中的位置,从0开始的位置索引。当<num>为0或正数时,表示从数组第一个元素开始 。当<num>大于数组当前元素数量时,将新元素插入数组的最后一个元素之后。当<num>为负数时,表示从数组的最后一个元素开始向前指定某个位置。如, 当传入-1时,表示向最后一个元素前的位置插入新的指定元素。当$each参数包含多个元素时,$each参数数组中的最后一个元素,在指定位置前。如果<num>的绝对值大于操作数组的长度,则从数组最前面插入新的元素。
行为
- 自mongodb5.0开始,UPDATE操作按照字段名称的字典顺序更新字段。当字段中包含数字时,按照数字顺序依次更新字段。当然,对一个文档的多个字段操作,是原子性的。
应用
向数组头部插入元素
创建students集合并插入数据
db.students.insertOne({_id: 1, scores: [100]})
构建数据更新语句,在scores数组元素100前插入50, 60, 70三个元素
db.students.updateOne(
{_id: 1},
{$push: {scores: {$each: [50,60,70], $position:0}}}
)
查看更新结果
db.students.find()
[
{
"_id": 1,
"scores": [
50,
60,
70,
100
]
}
]
在数组中间插入新元素
构建数据更新语句,向数组的第二个位置插入元素20, 30。
db.students.updateOne(
{_id: 1},
{$push: {scores: {$each: [20, 30], $position: 2}}}
)
查看数据更新结果
[
{
"_id": 1,
"scores": [
50,
60,
20,
30,
70,
100
]
}
]
使用负数索引向数组指定位置插入元素
构建数组更新语句,向数组中倒数第二个元素前插入元素 90, 80.
db.students.updateOne(
{_id: 1},
{$push: {scores: {$each: [90, 80], $position: -2}}}
)
查询更新结果
[
{
"_id": 1,
"scores": [
50,
60,
20,
30,
90,
80,
70,
100
]
}
]
标签:Mongodb,元素,UPDATE,each,插入,数组,scores,position
From: https://blog.csdn.net/wilsonzane/article/details/139736001