mongodb 修改数组嵌套字典中的字段名称_python-mongodb-修改优化-改字段名称

b137eaabf14bdc9fa2267de9d500b76e.png

背景:

某次开发中需要修改字段名称,由于时间紧,而自己对mongodb不熟,按照基本逻辑写完了代码并实现了功能,事后学习官方文档有更好的方法。

数据准备

ret = test_coll.insert_many([
    {
        "_id": 1,
        "alias": ["The American Cincinnatus", "The American Fabius"],
        "mobile": "555-555-5555",
        "nmae": {"first": "george", "last": "washington"}
    },

    {
        "_id": 2,
        "alias": ["My dearest friend"],
        "mobile": "222-222-2222",
        "nmae": {"first": "abigail", "last": "adams"}
    },

    {
        "_id": 3,
        "alias": ["Amazing grace"],
        "mobile": "111-111-1111",
        "nmae": {"first": "grace", "last": "hopper"}
    },
],
   )
# 文档中的nmae写错了, 需要改为name

解决方法:

# 方法1:查询所有的文档 遍历判断然后依次修改
def update_to_rename_one_by_one():
    documents_cursor = test_coll.find({})
    for document in documents_cursor:
        if 'nmae' in document.keys():
            _id = document['_id']
            name = document['nmae']
            document.pop('nmae')
            document['name'] = name
            ret = test_coll.update_one({'_id': _id}, {"$set": document})
            if ret.modified_count:
                print('rename success')


# 方法二:
def update_to_rename_all():
    ret = test_coll.update_many({}, {'$rename': {"nmae": "name"}})
    return ret.modified_count

总结:

  1. 第一种方法 查询出来 再遍历,然后遍历过程中针对字典进行修改操作,然后修改数据库中的文档 ,第二种方法,在查询数据库中就针对名称进行了修改,少了内存开销与运行时间;
  2. mongodb的官方文档写的非常清晰,可以修改匹配中的第一个,也可以修改所有,还可以修改嵌套字典中的字段名称,详细请看https://docs.mongodb.com/manual/reference/operator/update/rename/
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值