在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/Python  數(shù)據(jù)庫/ MongoDB 多個內(nèi)嵌文檔同時更新的問題

MongoDB 多個內(nèi)嵌文檔同時更新的問題

我正在使用MongoDB作為數(shù)據(jù)庫,今天在試圖同時更新一個文檔的多個內(nèi)嵌文檔時遇到了問題。

使用環(huán)境:Python3.6 PyMongo驅(qū)動

在更新之前的表格式:

{
    "_id" : 0,
    "sys" : {
        "group" : 0,
        "status" : 1,
        "regtime" : NumberLong(1527240646218)
    },
    "info" : {
        "name" : "桂小方"
    }
}

已經(jīng)生成的更新數(shù)據(jù):

{
    'sys': {
        'group': 0,
        'status': 2
    },
    'info': {
        'name': '桂小方',
        'mail': 'abc@abc.com',
        'phone': '+1234567'
    }
}

我需要得到的更新之后的表:

{
    "_id" : 0,
    "sys" : {
        "group" : 0,
        "status" : 2, // 這里發(fā)生更新
        "regtime" : NumberLong(1527240646218)
    },
    "info" : {
        "name" : "桂小方",
        'mail': 'abc@abc.com', // 這里發(fā)生更新
        'phone': '+1234567' // 這里發(fā)生更新
    }
}

但當我試圖使用 $set 更新器在以下語句中更新文檔:

database.users.update(
    {"_id": uid},
    {"$set": data} //這里的data代指上面的更新數(shù)據(jù)
)

但是卻得到了這樣的結(jié)果:

{
    "_id" : 0,
    "sys" : {
        "group" : 0,
        "status" : 2 // 我需要保留的regtime鍵消失了
    },
    "info" : {
        "name" : "桂小方",
        'mail': 'abc@abc.com', // 這里成功更新
        'phone': '+1234567' // 這里成功更新
    }
}

在Google上搜索之后我明白了問題的原因:使用 $set 更新器會對文檔中指定的鍵進行值替換,但是內(nèi)嵌文檔同樣會整個全部被提換成新的文檔;如果需要部分更新內(nèi)嵌文檔的值需要進行 info.$ 這樣的更新。

但是我的表沒有固定的模式,更新數(shù)據(jù)也是生成的,所以想請問大家有沒有直接可以同時對多個內(nèi)嵌文檔進行更新的方法。謝謝!

回答
編輯回答
墻頭草

你的理解可能有誤。info.$是對匹配的數(shù)組元素的更新,跟內(nèi)嵌文檔沒有什么關(guān)系。
不知道你上面的data具體內(nèi)容到底是什么。從結(jié)果來看應(yīng)該是:

data = {
    "sys" : {
        "group" : 0,
        "status" : 2
    },
    "info" : {
        "name" : "桂小方",
        'mail': 'abc@abc.com', // 這里發(fā)生更新
        'phone': '+1234567' // 這里發(fā)生更新
    }
}

才有可能得到你的結(jié)果。如果data確實是這個值,那這個結(jié)果是沒有問題的。想得到你要的結(jié)果,正確的更新語句應(yīng)該是:

db.users.update({
    "_id": uid
}, {
    'sys.status': data.sys.status,
    'info': data.info
});
2017年7月10日 02:35