$addToSet,以及更新其他字段?
$addToSet, along with updating other fields?
我在 MongoDB 中更新文档时遇到问题,其中涉及使用 Pymongo 添加到列表和更新某些字段。
总而言之,我想:
- 向列表添加一个值。
- 更新一些字段。
- 使用单个更新语句。
我尝试了两种方法,但都不起作用:
key = {'username':'user1'}
user_detail = {
'name':{'first':'Marie', 'last':'Bender'},
'items':{'$addtoset':{'cars':'BMW'}}
}
user_detail2 = {
'name':{'first':'Marie', 'last':'Bender'},
'$addtoset':{'items.cars':'BMW'}
}
mongo_collection.update(key, user_detail, upsert=True)
mongo_collection.update(key, user_detail2, upsert=True)
错误消息:“$addToSet”中的美元 ($) 前缀字段“$addToSet”对于存储无效。
我的预期结果:
之前:
{
'username':'user1',
'item': {'cars':['Merc','Ferrari'],'house':1}
}
预定之后:
{
'username':'user1',
'name': {'first':'Marie', 'last':'Bender'},
'item': {'cars':['Merc','Ferrari','BMW'],'house':1}
}
您的第二次尝试更接近,但您需要使用 $set
运算符来设置 name
的值:
user_detail2 = {
'$set': {'name': {'first': 'Marie', 'last': 'Bender'}},
'$addtoset': {'items.cars': 'BMW'}
}
我在 MongoDB 中更新文档时遇到问题,其中涉及使用 Pymongo 添加到列表和更新某些字段。
总而言之,我想:
- 向列表添加一个值。
- 更新一些字段。
- 使用单个更新语句。
我尝试了两种方法,但都不起作用:
key = {'username':'user1'}
user_detail = {
'name':{'first':'Marie', 'last':'Bender'},
'items':{'$addtoset':{'cars':'BMW'}}
}
user_detail2 = {
'name':{'first':'Marie', 'last':'Bender'},
'$addtoset':{'items.cars':'BMW'}
}
mongo_collection.update(key, user_detail, upsert=True)
mongo_collection.update(key, user_detail2, upsert=True)
错误消息:“$addToSet”中的美元 ($) 前缀字段“$addToSet”对于存储无效。
我的预期结果:
之前:
{
'username':'user1',
'item': {'cars':['Merc','Ferrari'],'house':1}
}
预定之后:
{
'username':'user1',
'name': {'first':'Marie', 'last':'Bender'},
'item': {'cars':['Merc','Ferrari','BMW'],'house':1}
}
您的第二次尝试更接近,但您需要使用 $set
运算符来设置 name
的值:
user_detail2 = {
'$set': {'name': {'first': 'Marie', 'last': 'Bender'}},
'$addtoset': {'items.cars': 'BMW'}
}