热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用python操作MongoDB

安装模块查find增加insert更新update删除delete

安装模块

技术分享图片

连接数据库

from pymongo import MongoClient

connect = MongoClient(host="127.0.0.1", port=27017)  # 连接到数据库主机
# 返回一个连接
# MongoClient(host=[‘127.0.0.1:27017‘], document_class=dict, tz_aware=False, cOnnect=True)

db = connect["day120"]  # 获取指定库的连接

查 find

# 查询匹配到的所有数据
print
(list(db.table01.find())) # 查询table01这张表的所有数据, 返回的是一个能够迭代的对象(使用迭代器的方法取值) # 当查询一个不存在或者为空的表时, 返回一个空列表
# 查询匹配到的所有数据 print(db.table01.find_one({"name": "sath"})) # 查询到: 返回一个字典, 注意字典中有ObjectId对象 # 查询不到返回一个None

增加 insert

# 插入一条数据
ret = db.table01.insert_one({"name": "yyy"}) # insert_one: 返回一个插入结果对象(InsertOneResult) # 使用InsertOneResult.inserted_id能够获取到刚插入的数据的ObjectId类型的对象 print(str(ret.inserted_id), type(ret.inserted_id)) # 5c2987a219b4ead318f8efc3
# 插入多条数据 ret
= db.table01.insert_many([{"name": "xxx"}, {"name": "yyy"}]) print(ret, type(ret), dir(ret)) # 插入多条数据, 返回的是InsertManyResult对象 # 使用InsertManyResult.inserted_ids能获取插入的所有数据的ObjectId print(ret.inserted_ids) # [ObjectId(‘5c2988e319b4eafb7416e67c‘), #ObjectId(‘5c2988e319b4eafb7416e67d‘)] # 返回的是一个列表, 里面存放所有的刚插入的数据的ObjectId ids = list(map(lambda x: str(x), ret.inserted_ids)) print(ids) # [‘5c2988e319b4eafb7416e67c‘, ‘5c2988e319b4eafb7416e67d‘]

更新 update

db.table01.update({条件}, {修改的值})
# 值相等的不会被更新
# 更新匹配到的第一数据
# ret = db.table01.update({"name": "yyy"}, {"$set": {"age": 68}})
print(ret, type(ret), dir(ret))
# 返回一个字典
# {‘n‘: 1, ‘nModified‘: 1, ‘ok‘: 1.0, ‘updatedExisting‘: True}


# 更新匹配到的第一条数据
ret = db.table01.update_one({"name": "yyy"}, {"$set": {"age": 48}})
print(ret, type(ret), dir(ret))
# 返回一个更新结果对象


# 更新所有匹配到的数据
ret = db.table01.update_many({"name": "yyy"}, {"$set": {"age": 45}})
# 返回一个更新结果对象
# ret.modified_count     更新的条目数     7
# ret.raw_result        更新的结果信息     {‘n‘: 7, ‘nModified‘: 7, ‘ok‘: 1.0, ‘updatedExisting‘: True}
# ret.matched_count     # 匹配到的条目数       7
print(ret, type(ret), dir(ret))

删除 delete, remove

# 删除匹配到第一条数据
db.table01.delete_one({条件})
ret = db.table01.delete_one({"name": "sath"})
print(ret.raw_result, type(ret), dir(ret))
# 返回删除的结果对象
# {‘n‘: 1, ‘ok‘: 1.0}
# 常用方法:
# ‘deleted_count‘,
# ‘raw_result‘

# 删除所有匹配到的数据
ret = db.table01.delete_many({"name":"xxx"})
print(ret.raw_result, type(ret), dir(ret))
# 返回一个删除结果对象
# 常用方法
# ‘deleted_count‘,
# ‘raw_result

# 删除所有的数据
ret = db.table01.remove()
print(ret, type(ret), dir(ret))
# 返回一个字典
# {‘n‘: 17, ‘ok‘: 1.0}

使用python操作MongoDB


推荐阅读
  • 本文深入探讨了原型模式在软件设计中的应用与实现。原型模式通过使用已有的实例作为原型来创建新对象,而不是直接通过类实例化。这种方式不仅简化了对象的创建过程,还提高了系统的灵活性和效率。具体来说,原型模式涉及一个支持克隆功能的接口或基类,子类通过实现该接口来提供具体的克隆方法,从而实现对象的快速复制。此外,文章还详细分析了原型模式的优缺点及其在实际项目中的应用场景,为开发者提供了实用的指导和建议。 ... [详细]
  • 本文详细探讨了Java集合框架的使用方法及其性能特点。首先,通过关系图展示了集合接口之间的层次结构,如`Collection`接口作为对象集合的基础,其下分为`List`、`Set`和`Queue`等子接口。其中,`List`接口支持按插入顺序保存元素且允许重复,而`Set`接口则确保元素唯一性。此外,文章还深入分析了不同集合类在实际应用中的性能表现,为开发者选择合适的集合类型提供了参考依据。 ... [详细]
  • 本文深入解析了 Apache 配置文件 `httpd.conf` 和 `.htaccess` 的优化方法,探讨了如何通过合理配置提升服务器性能和安全性。文章详细介绍了这两个文件的关键参数及其作用,并提供了实际应用中的最佳实践,帮助读者更好地理解和运用 Apache 配置。 ... [详细]
  • Python学习:环境配置与安装指南
    Python作为一种跨平台的编程语言,适用于Windows、Linux和macOS等多种操作系统。为了确保本地已成功安装Python,用户可以通过终端或命令行界面输入`python`或`python3`命令进行验证。此外,建议使用虚拟环境管理工具如`venv`或`conda`,以便更好地隔离不同项目依赖,提高开发效率。 ... [详细]
  • 本课程详细解析了Spring AOP的核心概念及其增强机制,涵盖前置增强、后置增强和环绕增强等类型。通过具体示例,深入探讨了如何在实际开发中有效运用这些增强技术,以提升代码的模块化和可维护性。此外,还介绍了Spring AOP在异常处理和性能监控等场景中的应用,帮助开发者更好地理解和掌握这一强大工具。 ... [详细]
  • 在2020年8月19日的深度分析中,我们探讨了HTML标签中同时存在`a`标签的`href`和`onclick`属性时的触发顺序问题。此外,还讨论了如何在一个自适应高度的父级`div`中,使两个子`div`中的一个固定高度为300px,另一个自动填充剩余空间的方法。最后,文章详细介绍了JavaScript异步加载的多种实现方式,包括但不限于`async`、`defer`属性以及动态脚本插入技术,为开发者提供了丰富的技术参考。 ... [详细]
  • 本文介绍了一种专为清洁工人设计的自定义文本烟花效果。通过该功能,用户可以输入特定的感谢或祝福语句,系统将生成绚丽的烟花动画,以表达对清洁工人的敬意和感激之情。该特效不仅美观,还能增强用户的互动体验,提升公共场合的氛围。 ... [详细]
  • 在MFC开发过程中,利用Windows内置的文件对话框可以显著提高文件操作的效率。本文总结了使用文件对话框进行文件选择和处理的经验,详细介绍了相关API的调用方法和参数设置,如`CFileDialog`类的使用、结构体`OPENFILENAME`的配置以及如何获取选中的文件路径。通过这些技巧,开发者可以快速实现文件的打开、保存等功能,提升应用程序的用户体验。 ... [详细]
  • Kali Linux 渗透测试实战指南:第24章 客户端安全威胁分析与防御策略
    客户端安全威胁分析与防御策略主要探讨了终端设备(如计算机、平板电脑和移动设备)在使用互联网时可能面临的各种安全威胁。本章详细介绍了这些设备如何作为信息和服务的提供者或接收者,以及它们在与服务器等其他系统交互过程中可能遇到的安全风险,并提出了有效的防御措施。 ... [详细]
  • 今天我们学习,数据库mongodb的使用,最下面有mongodb的下载链接。pipinstallpymongo首先安装pymongo,然后在需要用到的地方importpymongo ... [详细]
  • 学到了MongoDBMongo是一个基于分布式文件存储的数据库,由C++编写,旨在为Web应用提供可拓展的高性能数据存储解决方案.它介于关系数据库和非关系数据库之间,在非关系数据 ... [详细]
  • 本文深入探讨了 MXOTDLL.dll 在 C# 环境中的应用与优化策略。针对近期公司从某生物技术供应商采购的指纹识别设备,该设备提供的 DLL 文件是用 C 语言编写的。为了更好地集成到现有的 C# 系统中,我们对原生的 C 语言 DLL 进行了封装,并利用 C# 的互操作性功能实现了高效调用。此外,文章还详细分析了在实际应用中可能遇到的性能瓶颈,并提出了一系列优化措施,以确保系统的稳定性和高效运行。 ... [详细]
  • Python网络爬虫入门:利用urllib库进行数据抓取
    Python网络爬虫入门:利用urllib库进行数据抓取在数据科学和Web开发领域,Python凭借其简洁高效的特性成为首选语言。本文主要介绍了如何在Windows环境下使用Python的urllib库进行基本的网络数据抓取。考虑到命令行操作的不便,作者选择了Jupyter Notebook作为开发环境,不仅简化了配置过程,还提供了直观的数据处理和可视化功能。通过实例演示,读者可以轻松掌握urllib的基本用法,为深入学习网络爬虫技术打下坚实基础。 ... [详细]
  • 当前,众多初创企业对全栈工程师的需求日益增长,但市场中却存在大量所谓的“伪全栈工程师”,尤其是那些仅掌握了Node.js技能的前端开发人员。本文旨在深入探讨全栈工程师在现代技术生态中的真实角色与价值,澄清对这一角色的误解,并强调真正的全栈工程师应具备全面的技术栈和综合解决问题的能力。 ... [详细]
  • 在开发过程中,针对PHP生成PNG图像时的文字换行处理以及解析包含CDATA段的XML文件的方法进行了深入研究。通过编写特定的函数,成功解决了这些问题,为后续类似场景提供了宝贵的实践经验和技术支持。 ... [详细]
author-avatar
qzq9037091
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有