三、Python 操作 MongoDB ----非 ODM
文章目录
- 一、连接器的安装和配置
- 二、新增文档
- 三、查询文档
- 四、更新文档
- 五、删除文档
一、连接器的安装和配置
pymongo: MongoDB 官方提供的 Python 工具包。官方文档: https://pymongo.readthedocs.io/en/stable/ pip安装,命令如下:
pip install pymongo
管理 MongoDB 的主要步骤如下:
- 连接到 MongoDB 数据库系统
- 管理 MongoDB 数据库
- 管理 MongoDB 中的集合
- 管理 MongoDB 中的文档
第一步,连接 MongoDB:
# 方式一: 使用默认的配置
client = MongoClient()
# 方式二: 指定主机地址和端口号
client = MongoClient('localhost', 27017)
# 方式三: 使用URI连接参数
client = MongoClient('mongodb://localhost:27017/')
第二步,管理数据库:
#通过MongoClient对象来管理多个数据库获取数据库(逻辑库)对象
db = client.DATABASE_NAME
db = client["DATABASE_NAME"]
db = client.get_database(name=None, *args)
# 查看所有的数据库(逻辑库)
client.list_databases()
# 删除数据库(逻辑库)
client.drop_database(name_or_database, *args)
第三步,管理集合
# 通过数据库对象db来管理集合
# 获取集合对象
db = client.DATABASE_NAME
db.COLLECTION_NAME
client.DATABASE_NAME.COLLECTION_NAME
db.get_collection(name, *args)
# 查看当前数据库下的集合列表
db.list_collection_names()
# 删除集合
db.drop_collection(name_or_collection, *args)
基础操作示例:
# -*- coding: utf-8 -*-
# @Time : 2023-03-17 1:47
# @Author : AmoXiang
# @File : 1.数据库连接.py
# @Software: PyCharm
# @Blog : https://blog.csdn.net/xw1680from pymongo import MongoClient# 使用默认配置连接到数据库
# client = MongoClient()
# print(client)
# client.close()
# 指定主机地址和端口号连接到数据库
# client = MongoClient('localhost', 27017)
# 使用URI连接参数连接到数据库
client = MongoClient('mongodb://localhost:27017/')
print(client)
# client.close()
#
# # 访问数据库
# db = client.test
# db = client["test"]
# print(db)
# db = client.get_database('test')
# client.close()
# print(db)
#
# 查看有哪些数据库
db_list = client.list_databases()
# # db_list = client.list_database_names()
for item in db_list:print(item)
#
# 查看数据库下有哪些集合
db_test = client["test"]
for item in db_test.list_collection_names():print(item)
#
# # 集合对象操作
# data = db_test.students.find_one()
# data = client.test.students.find_one()
data = client.test.get_collection('students').find_one()
print(data)
二、新增文档
说明:pymongo 在插入数据时可以将 python 的对象转换成 BSON
insert_one():插入一个文档
# 调用方法
result = db.COLLECTION_NAME.insert_one(doc)
# 返回插入的文档ID
result.inserted _id
insert_many():批量新增文档。调用方法:
doc_list = [doc1,doc2]
result = db.COLLECTION_NAME.insert_many(doc_list)
示例:
# -*- coding: utf-8 -*-
# @Time : 2023-03-17 1:55
# @Author : AmoXiang
# @File : 2.插入数据.py
# @Software: PyCharm
# @Blog : https://blog.csdn.net/xw1680import pymongoclient = pymongo.MongoClient(host="localhost", port=27017)
db = client.temp
collection = db.students# 单条数据的插入
student1 = {"id": '20170101', "name": "AmoXiang", "age": 20, "gender": "male"}
result = collection.insert_one(student1)
print(result)
print(result.inserted_id)
# 多条数据的插入
student2 = {"id": '20170102', "name": "Jordan", "age": 21, "gender": "female"}
student3 = {"id": '20170103', "name": "Mike", "age": 22, "gender": "female"}
result = collection.insert_many([student2, student3])
print(result)
print(result.inserted_ids)
三、查询文档
pymongo 可以将查询的结果转换成 python 中的对象
常用方法:
find_one(): 按条件查询一个文档
find(): 按条件查询多个文档
count_documents(): 统计满足条件的文档总数
aggregate(): 聚合统计
.sort(): 排序
.skip().limit(): 分页
示例代码:
# -*- coding: utf-8 -*-
# @Time : 2023-03-18 15:03
# @Author : AmoXiang
# @File : 5.查询文档.py
# @Software: PyCharm
# @Blog : https://blog.csdn.net/xw1680from bson.objectid import ObjectId
from pymongo import MongoClient, ASCENDING, DESCENDINGclass LearnMongoDBSearch(object):""" MongoDB查询练习 """def __init__(self):self.client = MongoClient()def search_one(self):""" 查询一个文档 """temp_obj = self.client.test.newdb.find_one()print(temp_obj)print('喜欢分数:', temp_obj['likes'])# print('注册时间:', temp_obj['reg_date'].date())print('姓名:', temp_obj['uname'])def search_user_by_pk(self, pk):obj_id = ObjectId(pk)# user_obj = self.client.test.newdb.find_one({'_id': obj_id})# 面向对象的方法,有代码提示db = self.client.get_database('test')users = db.get_collection('newdb')user_obj = users.find_one({'_id': obj_id})print(user_obj)def search_many(self):""" 查询多个文档 """db = self.client.get_database('test')students = db.get_collection('students')# stu_list = students.find()# for item in stu_list:# print(item)# 查询年龄大于12岁的学生stu_list = students.find({'age': {'$gt': 12}}, {'stu_name': 1, 'class_name': 1, 'age': 1})for item in stu_list:# 注意: mongo中存储的整数转换成了浮点数print(item)def paginate(self, page=1, page_size=10):"""分页处理:param page: 当前的页:param page_size: 每一页数据大小:return:"""db = self.client.get_database('test')students = db.get_collection('students')offset = (page - 1) * page_sizestu_list = students.find().skip(offset).limit(page_size)return stu_listdef sort_data(self):""" 排序 """db = self.client.get_database('test')grades = db.get_collection('grades')# // 将学生的语文成绩从高到低排序# db.grades.find({"grade.course_name": "语文"}).sort({"grade.score": -1});## //将学生的语文成绩按照年龄和成绩排序# db.grades.find({"grade.course_name": "语文"}).sort({"age": -1, "grade.score": -1});# db.grades.find({"grade.course_name": "语文"}).sort({"grade.score": -1, "age": -1});# 按某一列排序# data_list = grades.find({"grade.course_name": "语文"}).sort("grade.score", DESCENDING);# for item in data_list:# print(item)# 按多列排序data_list = grades.find({"grade.course_name": "语文"}).sort([('age', DESCENDING),("grade.score", DESCENDING),])for item in data_list:print(item)def counter_students(self):""" 统计newdb中文档总数 """db = self.client.get_database('test')newdb = db.get_collection('newdb')# result = newdb.count_documents({})result = newdb.count_documents({"uname": {"$eq": "张三"}})print(result)def test_aggregate(self):"""聚合统计:及格的学生成绩"""db = self.client.get_database('test')grades = db.get_collection('grades')result = grades.aggregate([# //where{'$match': {"grade.score": {'$gte': 60}}},# //group by{'$group': {'_id': "$stu_no",'total': {'$sum': 1}}},# // having{'$match': {'total': {'$eq': 3}}}])for item in result:print(item)if __name__ == '__main__':obj = LearnMongoDBSearch()# obj.search_one()# obj.search_user_by_pk('6411ee77b6170000b4003f95')# obj.search_many()# stu_list = obj.paginate(page=3)# for item in stu_list:# print(item)# obj.sort_data()# obj.counter_students()obj.test_aggregate()
四、更新文档
回顾,更新数据表达式,如下表所示:
修改一个文档,调用方法:
update_one(filter, update, *args)
替换一个文档,调用方法:
replace_one(filter, replacement, *args)
批量修改文档,调用方法:
result = db.COLLECTION_NAME.update_many(filter,update,*args)
快捷方法:
find_one_and_update(filter, update, *args) # 修改一个文档
find_one_and_replace(filter, replacement, *args) # 替换一个文档
# 注意返回值的不同
返回结果:
acknowledged:结果是否已经被确认
modified_count:修改的文档数
matched_count:满足条件的文档数
raw_result:原始数据
upserted_id:更新的ID (upsert=True)
示例代码:
# -*- coding: utf-8 -*-
# @Time : 2023-03-18 14:56
# @Author : AmoXiang
# @File : 4.修改文档.py
# @Software: PyCharm
# @Blog : https://blog.csdn.net/xw1680from pymongo import MongoClientclass LearnMongoDBUpdate(object):""" MongoDB更新练习 """def __init__(self):self.client = MongoClient()def test_update_one(self):""" 更新一个文档 """db = self.client.get_database('test')newdb = db.get_collection('newdb')result = newdb.update_one({}, {'$set': {'likes': 70}})print(result.modified_count)def test_replace_one(self):""" 替换一个文档 """db = self.client.get_database('test')newdb = db.get_collection('newdb')result = newdb.replace_one({}, {'uname': '张三'})print(result.modified_count)def test_update_many(self):""" 批量更新文档 """db = self.client.get_database('test')newdb = db.get_collection('newdb')result = newdb.update_many({}, {'$set': {'likes': 90}})print('修改的数量:', result.modified_count)print('满足条件的数量:', result.matched_count)def test_update_shortcut(self):""" 更新文档的快捷方法 """db = self.client.get_database('test')newdb = db.get_collection('newdb')# 此处返回一个文档对象result = newdb.find_one_and_update({}, {'$set': {'sex': '未知'}})print(result['_id'])if __name__ == '__main__':obj = LearnMongoDBUpdate()# obj.test_update_one()# obj.test_replace_one()# obj.test_update_many()obj.test_update_shortcut()
五、删除文档
删除一个文档,调用方法如下:
result = db.COLLECTION_NAME.delete_one(filter, *args)
# 返回已经删除的记录数 result.deleted_count
# 删除时返回文档对象
find_one_and_delete(filter, *args)
批量删除文档,调用方法:
result = db.COLLECTION_NAME.delete_many(filter, *args)
# 返回已经删除的记录数
result. deleted_count
示例代码:
# -*- coding: utf-8 -*-
# @Time : 2023-03-18 14:34
# @Author : AmoXiang
# @File : 3.删除文档.py
# @Software: PyCharm
# @Blog : https://blog.csdn.net/xw1680from pymongo import MongoClientclass LearnMongoDBDelete(object):""" MongoDB删除练习 """def __init__(self):self.client = MongoClient()def test_delete_one(self):""" 删除一个文档 """db = self.client.get_database('test')newdb = db.get_collection('newdb')result = newdb.delete_one({})print(result.deleted_count)def test_delete_many(self):""" 批量删除文档 """db = self.client.get_database('test')users = db.get_collection('newdb')# 删除所有的数据result = users.delete_many({"likes": {"$lte": 90}})print(result.deleted_count)def test_delete_shortcut(self):""" 删除文档的快捷方法 """db = self.client.get_database('test')newdb = db.get_collection('newdb')result = newdb.find_one_and_delete({})print(result['title'])if __name__ == '__main__':obj = LearnMongoDBDelete()# obj.test_delete_one()# obj.test_delete_shortcut()obj.test_delete_many()
至此今天的学习就到此结束了,笔者在这里声明,笔者写文章只是为了学习交流,以及让更多学习数据库的读者少走一些弯路,节省时间,并不用做其他用途,如有侵权,联系博主删除即可。感谢您阅读本篇博文,希望本文能成为您编程路上的领航者。祝您阅读愉快!
好书不厌读百回,熟读课思子自知。而我想要成为全场最靓的仔,就必须坚持通过学习来获取更多知识,用知识改变命运,用博客见证成长,用行动证明我在努力。
如果我的博客对你有帮助、如果你喜欢我的博客内容,请点赞
、评论
、收藏
一键三连哦!听说点赞的人运气不会太差,每一天都会元气满满呦!如果实在要白嫖的话,那祝你开心每一天,欢迎常来我博客看看。
编码不易,大家的支持就是我坚持下去的动力。点赞后不要忘了关注
我哦!
相关文章:

三、Python 操作 MongoDB ----非 ODM
文章目录一、连接器的安装和配置二、新增文档三、查询文档四、更新文档五、删除文档一、连接器的安装和配置 pymongo: MongoDB 官方提供的 Python 工具包。官方文档: https://pymongo.readthedocs.io/en/stable/ pip安装,命令如下࿱…...
求最大公约数和最小公倍数---辗转相除法(欧几里得算法)
目录 一.GCD和LCM 1.最大公约数 2.最小公倍数 二.暴力求解 1.最大公约数 2.最小公倍数 三.辗转相除法 1.最大公约数 2.最小公倍数 一.GCD和LCM 1.最大公约数 最大公约数(Greatest Common Divisor,简称GCD)指的是两个或多个整数共有…...

音视频开发_获取媒体文件的详细信息
一、前言 做音视频开发过程中,经常需要获取媒体文件的详细信息。 比如:获取视频文件的总时间、帧率、尺寸、码率等等信息。 获取音频文件的的总时间、帧率、码率,声道等信息。 这篇文章贴出2个我封装好的函数,直接调用就能获取媒体信息返回,copy过去就能使用,非常方便。…...

Springboot集成Swagger
一、Swagger简介注意点! 在正式发布的时候要关闭swagger(出于安全考虑,而且节省内存空间)之前开发的时候,前端只用管理静态页面, http请求到后端, 模板引擎JSP,故后端是主力如今是前…...

Vue全新一代状态管理库 Pinia【一篇通】
文章目录前言1. Pinia 是什么?1.1 为什么取名叫 Pinia?1.2. 为什么要使用 Pinia ?2. 安装 Pinia2.1.创建 Store2.1.1. Option 类型 Store2.1.2 Setup 函数类型 Store2.1.3 模板中使用3. State 的使用事项(Option Store )3.1 读取 State3.2 …...

STM32 -4 关于STM32的RAM、ROM
一 stm32 的flash是什么、有什么用、注意事项、如何查看 一 、说明 它主要用于存储代码,FLASH 存储器的内容在掉电后不会丢失,STM32 芯片在运行的时候,也能对自身的内部 FLASH 进行读写,因此,若内部 FLASH 存储了应用…...

第一个 Qt 程序
第一个 Qt 程序 “hello world ”的起源要追溯到 1972 年,贝尔实验室著名研究员 Brian Kernighan 在撰写 “B 语言教程与指导(Tutorial Introduction to the Language B)”时初次使用(程序),这是目前已 知最早的在计算机著作中将…...

Spring注解驱动开发--AOP底层原理
Spring注解驱动开发–AOP底层原理 21. AOP-AOP功能测试 AOP:【动态代理】 指在程序运行期间动态的将某段代码切入到指定方法指定位置进行运行的编程方式; 1、导入aop模块:Spring AOP,(Spring-aspects) 2、定义一个业务逻辑类(Ma…...
对象的动态创建和销毁以及对象的复制,赋值
🐶博主主页:ᰔᩚ. 一怀明月ꦿ ❤️🔥专栏系列:线性代数,C初学者入门训练,题解C,C的使用文章,「初学」C 🔥座右铭:“不要等到什么都没有了,才…...

JVM调优,调的是什么?目的是什么?
文章目录前言一、jvm是如何运行代码的?二、jvm的内存模型1 整体内存模型结构图2 堆中的年代区域划分3 对象在内存模型中是如何流转的?4 什么是FULL GC,STW? 为什么会发生FULL GC?5 要调优,首先要知道有哪些垃圾收集器及哪些算法6 调优不是盲目的,要有依据,几款内…...

docker部署zabbix监控
docker部署zabbix监控 1、环境说明 公有云ubuntu22.04 系统->部署docker环境zabbix-server 6.4 2、准备docker环境 更新apt以及安装一些必要的系统工具 sudo apt-get update sudo apt-get -y install apt-transport-https ca-certificates curl software-properties-co…...

C语言刷题(6)(猜名次)——“C”
各位CSDN的uu们你们好呀,今天,小雅兰还是在复习噢,今天来给大家介绍一个有意思的题目 题目名称: 猜名次 题目内容: 5位运动员参加了10米台跳水比赛,有人让他们预测比赛结果: A选…...
两年外包生涯,感觉自己废了一半....
先说一下自己的情况。大专生,17年通过校招进入湖南某软件公司,干了接近2年的点点点,今年年上旬,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了五年的功能测试…...

【python】喜欢XJJ?这不得来一波大采集?
前言 大家早好、午好、晚好吖 ❤ ~欢迎光临本文章 俗话说的好:技能学了~就要用在自己喜欢得东西上!! 这我不得听个话~我喜欢小姐姐,跳舞的小姐姐 这不得用python把小姐姐舞采集下来~嘿嘿嘿 完整源码、素材皆可点击文章下方名片…...

公司测试员用例写得乱七八糟,测试总监制定了这份《测试用例编写规范》
统一测试用例编写的规范,为测试设计人员提供测试用例编写的指导,提高编写的测试用例的可读性,可执行性、合理性。为测试执行人员更好执行测试,提高测试效率,最终提高公司整个产品的质量。 一、范围 适用于集成测试用…...

LeetCode 热题 HOT 100【题型归类汇总,助力刷题】
介绍 对于算法题,按题型类别刷题才会更有成效,因此我这里在网上搜索并参考了下 “🔥 LeetCode 热题 HOT 100” 的题型归类,并在其基础上做了一定的完善,希望能够记录自己的刷题历程,有所收获!具…...

【Java进阶篇】—— File类与IO流
一、File类的使用 1.1 概述 File 类以及本章中的各种流都定义在 java.io 包下 一个File对象代表硬盘或网络中可能存在的一个文件或文件夹(文件目录) File 能新建、删除、重命名 文件和目录,但 File不能访问文件内容本身。如果我们想要访问…...

Mysql 竟然还有这么多不为人知的查询优化技巧,还不看看?
前言 Mysql 我随手造200W条数据,给你们讲讲分页优化 MySql 索引失效、回表解析 今天再聊聊一些我想分享的查询优化相关点。 正文 准备模拟数据。 首先是一张 test_orde 表: CREATE TABLE test_order (id INT(11) NOT NULL AUTO_INCREMENT,p_sn VARCHA…...
MATLAB算法实战应用案例精讲-【智能优化算法】海洋捕食者算法(MPA) (附MATLAB和python代码实现)
目录 前言 知识储备 Lvy 飞行 布朗运动 算法原理 算法思想 数学模型...
Spring @Profile
1. Overview In this tutorial, we’ll focus on introducing Profiles in Spring. Profiles are a core feature of the framework — allowing us to map our beans to different profiles — for example, dev, test, and prod. We can then activate different profiles…...
Python爬虫实战:研究MechanicalSoup库相关技术
一、MechanicalSoup 库概述 1.1 库简介 MechanicalSoup 是一个 Python 库,专为自动化交互网站而设计。它结合了 requests 的 HTTP 请求能力和 BeautifulSoup 的 HTML 解析能力,提供了直观的 API,让我们可以像人类用户一样浏览网页、填写表单和提交请求。 1.2 主要功能特点…...

如何在看板中体现优先级变化
在看板中有效体现优先级变化的关键措施包括:采用颜色或标签标识优先级、设置任务排序规则、使用独立的优先级列或泳道、结合自动化规则同步优先级变化、建立定期的优先级审查流程。其中,设置任务排序规则尤其重要,因为它让看板视觉上直观地体…...
django filter 统计数量 按属性去重
在Django中,如果你想要根据某个属性对查询集进行去重并统计数量,你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求: 方法1:使用annotate()和Count 假设你有一个模型Item,并且你想…...

Module Federation 和 Native Federation 的比较
前言 Module Federation 是 Webpack 5 引入的微前端架构方案,允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...

DBAPI如何优雅的获取单条数据
API如何优雅的获取单条数据 案例一 对于查询类API,查询的是单条数据,比如根据主键ID查询用户信息,sql如下: select id, name, age from user where id #{id}API默认返回的数据格式是多条的,如下: {&qu…...

Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决
Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决 问题背景 在一个基于 Spring Cloud Gateway WebFlux 构建的微服务项目中,新增了一个本地验证码接口 /code,使用函数式路由(RouterFunction)和 Hutool 的 Circle…...

关键领域软件测试的突围之路:如何破解安全与效率的平衡难题
在数字化浪潮席卷全球的今天,软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件,这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下,实现高效测试与快速迭代?这一命题正考验着…...

【Linux】Linux 系统默认的目录及作用说明
博主介绍:✌全网粉丝23W,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…...
Leetcode33( 搜索旋转排序数组)
题目表述 整数数组 nums 按升序排列,数组中的值 互不相同 。 在传递给函数之前,nums 在预先未知的某个下标 k(0 < k < nums.length)上进行了 旋转,使数组变为 [nums[k], nums[k1], …, nums[n-1], nums[0], nu…...
用鸿蒙HarmonyOS5实现中国象棋小游戏的过程
下面是一个基于鸿蒙OS (HarmonyOS) 的中国象棋小游戏的实现代码。这个实现使用Java语言和鸿蒙的Ability框架。 1. 项目结构 /src/main/java/com/example/chinesechess/├── MainAbilitySlice.java // 主界面逻辑├── ChessView.java // 游戏视图和逻辑├──…...