MongoDB

关注公众号 jb51net

关闭
首页 > 数据库 > MongoDB > Mongodb使用$push向数组中插入数据

Mongodb在UPDATE操作中使用$push向数组中插入数据的方法

投稿:mrr

在update操作中,使用$push操作符向数组中插入新的元素,按照相应的语法,使用$push操作符,下面通过本文给大家分享Mongodb在UPDATE操作中使用$push向数组中插入数据的方法,感兴趣的朋友一起看看吧

学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第69篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。如果您认为我的文章对您有帮助或者解决您的问题,欢迎在文章下面点个赞,或者关注威赞。谢谢。

定义

在update操作中,使用$push操作符向数组中插入新的元素。按照下面的语法,使用$push操作符

{$push: {<field1>: <value1>, ...}}

当向嵌入式文档或数组中的数组字段插入元素时,使用点操作符。

行为

操作符

描述

$each

向指定数组一次性添加多个元素

$slice

限制操作数组的容量,需要和$each操作符搭配使用

$sort

对指定数组进行排序,需要和$each操作符搭配使用

$position

指定新元素在数组中插入的位置,需要和$each操作符搭配使用。默认新的元素插入到数组的结尾

当执行$push操作时,当用户指定对数组排序或限制数组长度时,update按照下面的顺序执行$push操作。

应用

创建students集合并插入数据

db.students.insertOne({_id:1,scores: [44,78,38,80]})

向数组中插入元素

db.students.updateOne({_id:1},{$push: {scores: 89}})

将指定数值插入多个文档的数组字段中

向students集合插入新文档

db.students.insertMany([
    {_id:2,scores: [45,78,38,80,89]},
    {_id:3,scores: [46,78,38,80,89]},
    {_id:4,scores: [47,78,38,80,89]},
])

构建UPDATE语句,向students所有文档的scores字段插入新值95

db.students.updateMany({},{$push: {scores: 95}})

向数组中插入多个数值

在$push中使用$each操作符,将多个值插入数组中。

db.students.updateOne({_id:1},{$push: {scores: {$each: [90, 92, 85]}}})

在$push操作符中使用多个数组更新操作符

向students集合中插入文档

db.students.insertMany([
    {_id:5, quizzes: [
        {wk:1, score: 10},
        {wk:2, score: 8},
        {wk:3, score: 5},
        {wk:4, score: 6}
    ]}
])

构建数据更新语句,完成下面几个操作

db.students.updateOne(
    {_id:5},
    {
        $push: {
            quizzes: {
                $each: [
                    {wk:5, score: 8},
                    {wk:6, score: 7}, 
                    {wk:7, score: 6}
                ],
                $sort: {score: -1},
                $slice: 3
            }
        }
    }
)

到此这篇关于Mongodb在UPDATE操作中使用$push向数组中插入数据的方法的文章就介绍到这了,更多相关Mongodb使用$push向数组中插入数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文