MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Актуализирайте обект в масива в mongoDb с помощта на mongoose

Обектите (документи) в масива в колекцията MongoDB се наричат ​​- поддокументи

В този случай, за да актуализирате конкретен поддокумент със собствен _id , можете да използвате Mongoose findOneAndUpdate метод:

play.findOneAndUpdate({
    "_id": "59b7e839200a5c00ee2d2851",
    "playesList._id": "59b2a4f749fee40959e556d3"
}, {
    "$set": {
        "playesList.$.name": "something"
    }
}, function(error, success) {

})

първо трябва да намерите документ в колекция с:

"_id": "59b7e839200a5c00ee2d2851"

след това намерете поддокумента по неговия _id използвайки втори параметър:

"playesList._id": "59b2a4f749fee40959e556d3"

и когато намерите поддокумента, който искате да актуализирате, използвайте $set оператор за задаване на нова стойност на name свойство на намерен поддокумент:

"$set": {
    "playesList.$.name": "something"
}

Обърнете внимание, че findOneAndUpdate връща предишното състояние на актуализирания документ.

Работещ пример:

var express = require('express')
var app = express()
var router = require('express').Router()
var mongoose = require('mongoose')
var Schema = mongoose.Schema

mongoose.connect('mongodb://localhost:27017/stackoverflowanswer')
mongoose.Promise = global.Promise

var PlayerSchema = new Schema({
    play: String,
    playersList: [{
        name: String
    }]
})

var Player = mongoose.model('Players', PlayerSchema)

app.use('/', router)

router.get('/add-player', function(req, res, next) {
    var player = new Player()

    player._id = "59b7e839200a5c00ee2d2851"
    player.play = "New"
    player.playersList.push({
        _id: "59b2a4f749fee40959e556d3",
        name: "abcd"
    }, {
        _id: "59b2a4f749fee40959e556d4",
        name: "pqrs"
    })

    player.save(function(err) {
        if (err) throw err

        res.json({
            message: 'Success'
        })
    })
})

router.get('/update-player', function(req, res, next) {
    Player.findOneAndUpdate({
        "_id": "59b7e839200a5c00ee2d2851",
        "playersList._id": "59b2a4f749fee40959e556d3"
    }, {
        "$set": {
            "playersList.$.name": "wxyz"
        }
    }, function(error, success) {
        if (error) throw error

        res.json({
            message: 'Success'
        })
    })
})

app.listen(8080, function() {
    console.log('Node.js listening on port ' + 8080)
})


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Интегриране на Power BI с Spring Angular

  2. Как да конкатенираме масиви от множество документи в MongoDB?

  3. Как да инсталирате MongoDB 4.2 на системи RedHat/ CentOS 7

  4. Mongo Заявка за подполета

  5. Агрегиране на Mongodb по дни въз основа на unix timestamp