三、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…...
Vue3电商项目实战-个人中心模块4【09-订单管理-列表渲染、10-订单管理-条件查询】
文章目录09-订单管理-列表渲染10-订单管理-条件查询09-订单管理-列表渲染 目的:完成订单列表默认渲染。 大致步骤: 定义API接口函数抽取单条订单组件获取数据进行渲染 落的代码: 1.获取订单列表API借口 /*** 查询订单列表* param {Number…...
【十二天学java】day01-Java基础语法
day01 - Java基础语法 1. 人机交互 1.1 什么是cmd? 就是在windows操作系统中,利用命令行的方式去操作计算机。 我们可以利用cmd命令去操作计算机,比如:打开文件,打开文件夹,创建文件夹等。 1.2 如何打…...
【面试题】闭包是什么?this 到底指向谁?
一通百通,其实函数执行上下文、作用域链、闭包、this、箭头函数是相互关联的,他们的特性并不是孤立的,而是相通的。因为内部函数可以访问外层函数的变量,所以才有了闭包的现象。箭头函数内没有 this 和 arguments,所以…...
汽车4S店业务管理软件
一、产品简介 它主要提供给汽车4S商店,用于管理各种业务,如汽车销售、售后服务、配件、精品和保险。整个系统以客户为中心,以财务为基础,覆盖4S商店的每一个业务环节,不仅可以提高服务效率和客户满意度,…...
基于 pytorch 的手写 transformer + tokenizer
先放出 transformer 的整体结构图,以便复习,接下来就一个模块一个模块的实现它。 1. Embedding Embedding 部分主要由两部分组成,即 Input Embedding 和 Positional Encoding,位置编码记录了每一个词出现的位置。通过加入位置编码可以提高模型的准确率,因为同一个词出现在…...
算法小抄6-二分查找
二分查找,又名折半查找,其搜索过程如下: 从数组中间的元素开始,如果元素刚好是要查找的元素,则搜索过程结束如果搜索元素大于或小于中间元素,则排除掉不符合条件的那一半元素,在剩下的数组中进行查找由于每次需要排除掉一半不符合要求的元素,这需要数组是已经排好序的或者是有…...
大学四年..就混了毕业证的我,出社会深感无力..辞去工作,从头开始
时间如白驹过隙,一恍就到了2023年,今天最于我来说是一个值得纪念的日子,因为我收获了今年的第一个offer背景18年毕业,二本。大学四年,也就将就混了毕业证和学位证。毕业后,并未想过留在湖南,就回…...
C语言数据结构初阶(6)----链表常见OJ题
CSDN的uu们,大家好!编程能力的提高不仅需要学习新的知识,还需要大量的练习。所以,C语言数据结构初阶的第六讲邀请uu们一起来看看链表的常见oj题目。移除链表元素原题链接:203. 移除链表元素 - 力扣(Leetcod…...
关键字 const
目录 一、符号常量与常变量 二、const的用法 2.1 const常用方法 2.2 const用于指针 2.2.1 p指针所指的对象值不能改变,但是p指针的指向可以改变 2.2.2 常指针p的指向不能改变,但是所指的对象的值可以改变 2.2.3 p所指对象的指向以及对象的值都不可…...
MybatisPlus------MyBatisX插件:快速生成代码以及快速生成CRUD(十二)
MybatisPlus------MyBatisX插件(十二) MyBatisX插件是IDEA插件,如果想要使用它,那么首先需要在IDEA中进行安装。 安装插件 搜索"MyBatisX",点击Install,之后重启IDEA即可。 插件基本用途&…...
校园网站系统建设需求/短视频精准获客系统
2019独角兽企业重金招聘Python工程师标准>>> 1. nodejs/npm安装配置 nodejs下载: http://nodejs.org/download/ nodejs环境变量: PATHC:\Program Files\nodejs; 测试: node -v npm最新版下载: https://github.co…...
做网站属于广告费吗/链接购买
php表单的种类有:1、text;2、color;3、date;4、datetime;5、email;6、month;7、number;8、range;9、search;10、tel;11、url。php表单的种类&…...
wordpress tags云/谷歌浏览器 安卓下载2023版官网
相信很多接触到Web开发方面的人都知道Yahoo Developer Network的一篇文章 “Best Practices for Speeding Up Your Web Site” 我觉得这篇文章称作Web开发的圣经也不算过分,他们的34条铁律我几乎每隔几天都要温习一下并努力实践到自己的工作中。没有看到过这篇文章的…...
做网站卖别人的软件可以吗/深圳网站seo地址
Hello,大家好,今天继续排序系列之六讲☞《快速排序法进阶》,之所以称为进阶,那肯定是因为比vision 1.0高明。为了方便大家比较,首先同大家一起回顾一下第一版快速排序的原理。 首先拿序列的最后一项作为基准,其余项依次和他做比较…...
网站首页被降权/谷歌浏览器下载手机版官网
https://blog.csdn.net/zhao_teng/article/details/104669281/...
亳州企业网站建设/2345网址导航是病毒吗
将 arguments 对象转换为数组 arguments 对象是函数内部可访问的类似数组的对象,其中包含传递给该函数的参数的值。 与其他数组不同,这里我们可以访问值并获得长度(length),但是不能在其上使用其他数组方法。 幸运的…...