在MongoDb中是否可以对除了已经更新的字段(例如addToSet)以外的所有内容执行更新?
我将信息存储在python词典中,该词典由用户更新。然后我想使用这个字典来更新MongoDb中的条目。其中一个字段是一个数组,我想插入字典值,如果它不存在。其他一切都可以替换。我遇到的问题是使用set与整个字典替换单个值的数组。为了说明问题:
我创建了一个字典
thing = {}
thing['name'] = 'fruit'
thing['color'] = 'green'
thing['types'] = ['apple', 'pear', 'kiwi']
我插入它:
c_users.insert_one(thing)
用户标记一些要更新的字段
thing2 = {}
thing2['name'] = 'fruit'
thing2['color'] = 'darkgreen'
thing2['types'] = 'mango'
然后我尝试更新数据库
c_users.update({' name':thing2 [' name']},{' $ addToSet':{' types' :thing2 ['类型']}' $设定' {'颜色':thing2}})
是否可以使此方法有效?如果没有其他方法可以实现相同的最终结果,例如使用变量而不是thing2 [' types'],但最好将所有值保留在字典中。
答案 0 :(得分:0)
您可以从更新文档中弹出“类型”值:
>>> c_users.find_one()
{u'color': u'green', u'_id': ObjectId('553fddc967d5bd0b07022477'), u'name': u'fruit', u'types': [u'apple', u'pear', u'kiwi']}
>>> thing2 = {'name': 'fruit', 'color': 'darkgreen', 'types': 'mango'}
>>> c_users.update({'name': thing2['name']}, {'$addToSet': {'types': thing2.pop('types')}, '$set': thing2})
{u'nModified': 1, u'ok': 1, u'n': 1, 'updatedExisting': True, u'electionId': ObjectId('553fc845f09926d0bb959eb7'), u'lastOp': Timestamp(1430249053, 1)}
>>> c_users.find_one()
{u'color': u'darkgreen', u'_id': ObjectId('553fddc967d5bd0b07022477'), u'name': u'fruit', u'types': [u'apple', u'pear', u'kiwi', u'mango']}