当前位置: 首页 > news >正文

4.5 MongoDB 文档存储

目录

1. 相关安装

2. Pycharm可视化观察MongoDB

3. python使用 MongoDB 最初流程代码

4. 插入、查询、更新、删除数据

4.1 插入数据

4.2 查询数据

4.3 更新数据

4.3.1 更新一条数据

4.3.2 更新多条数据

4.4 删除数据

5. 计数、排序、偏移

5.1 计数

5.2 排序

5.3 偏移

1. 相关安装

        MongoDB数据库安装(注意自己的文件路径):MongoDB的安装配置教程(很详细,你想要的都在这里)_mongodb安装-CSDN博客

        python语言使用该数据库要安装pymongo数据包:

打开,conda install pymongo

2. Pycharm可视化观察MongoDB

        在Pycharm右侧或者左下角找到下图1图标,然后按步骤进行。

        之后改个数据源名称,MongoDB不需要密码(如果一直连接不上,可能是没启动MongoDB),若弹出要下载啥的,直接下载,之后点确定,就可在右侧看到之后对MongoDB的操作。

3. python使用 MongoDB 最初流程代码

        导入pymongo库,创建连接对象,指定数据库,指定集合(相对于mysql的表)

import pymongoclient = pymongo.MongoClient("mongodb://localhost:27017/")  # 1、创建连接对象
# client = pymongo.MongoClient(host='localhost', port=27017)    # 同上效果
db = client.test    # 2、指定数据库test(会直接创建一个数据库)
collection = db.students    # 3、指定集合students

        在右侧可看到结果如下(没出现,点击两个循环箭头的刷新就好):

4. 插入、查询、更新、删除数据

        在基本代码下进行以下操作。

4.1 插入数据

       collection.insert_one()插入一条数据(数据为字典),返回的是InsertOneResult 对象,可用inserted_id来获取_id;(个人认为,这里的_id相当于mysql的主键)

        collection.insert_many()插入多条数据,参数为包含多个字典的列表。返回的是InsertManyResult 对象,可用inserted_ids来获取多个数据的_id;

student1 = {'id': '100','name': '小明','age': 20,'gender': '男'
}
result1 = collection.insert_one(student1)
print(result1, result1.inserted_id)student2 = {'id': '101','name': '小红','age': 22,'gender': '女'
}
student3 = {'id': '102','name': '小强','age': 26,'gender': '男'
}
result2 = collection.insert_many([student2, student3])
print(result2, result2.inserted_ids)

结果如下:

4.2 查询数据

        使用collection.find_one()查询一条数据,参数是一个字典,返回一个字典,_id属性是自动添加的。

        collection.find()可查询多条数据,返回一个生成器,用for 遍历出来结果。下面是查询年龄小于25岁的,这时需要比较符号。

data = collection.find_one({"id": '101'})
print(type(data), data)data2 = collection.find({'age': {'$lt': 25}})
print(data2)
for data in data2:print(data)

比较符号如下:

还可以进行正则匹配,需要功能符号,如下:

4.3 更新数据

        在sduents表中的数据为:

4.3.1 更新一条数据

        现要更新第一条数据的年龄,首先要知道这条数据的辨识条件conditon,之后使用 collection.update_one()去更改,第一个参数为conditon,第二个参数是个字典,要使用$set操作符作为键,值为数据对象及更改内容。

condition = {'age': 20}
result = collection.update_one(condition, {'$set': {‘age’: 30}})
print(result)    # 输出:<pymongo.results.UpdateResult object at 0x000001D9787F07C0>
# 上个输出不唯一,每次都可能不同
print(result.matched_count, result.modified_count)    # 匹配条数和影响条数 输出: 1 1

4.3.2 更新多条数据

        现要将年龄大于25岁学生年龄都加一,代码如下:

condition = {'age': {'$gt': 25}}
result = collection.update_many(condition, {'$inc': {'age': 1}})
print(result)
print(result.matched_count, result.modified_count)    # 输出:2 2

       结果如下:

 如果该条件下的数据只要一条,使用update_many()会报错。

4.4 删除数据

        collection.remove()可删一条和多条数据,collection.delete_one()和collection.delete_many()删除一条和多条。

result1 = collection.remove({'age': {'$lt': 25}})    # 也可删多条数据
# collection.delete_one({'age': {'$lt':25}}) # 删一条
# 上面的remove()方法官方不推荐使用,会报警告
print(result1)
result2 = collection.delete_many({'age': {'$gt': 25}})
print(result2, result2.deleted_count)

5. 计数、排序、偏移

        初始集合:

        以下代码在最初流程代码后进行。

5.1 计数

number1 = collection.find().count() 
print(number1) # 3
number2 = collection.count()    # 所有数据条数
print(number2)  # 3
number3 = collection.find({'age':{'$lt': 25}}).count()
print(number3)    # 2
# 上述都会报警告,但会正常进行number4 = collection.count_documents({'age': {'$lt': 25}})
print(number4)    # 不警告,但不加参数会报错

5.2 排序

results = collection.find().sort("id", pymongo.ASCENDING)
# pymongo.ASCENDING为顺序,pymongo.DESCENDING为倒序
for result in results:print(result, result['id'])

5.3 偏移

        利用skip()方法跳过前几个,limit()方法会限制获取结果。现在对上述结果进行跳过第一个,只要一个结果:

results = collection.find().sort("id", pymongo.DESCENDING).skip(1).limit(1)
for result in results:print(result, result['id'])

本人新手,若有错误,欢迎指正;若有疑问,欢迎讨论。若文章对你有用,点个小赞鼓励一下,谢谢,一起加油吧!

相关文章:

4.5 MongoDB 文档存储

目录 1. 相关安装 2. Pycharm可视化观察MongoDB 3. python使用 MongoDB 最初流程代码 4. 插入、查询、更新、删除数据 4.1 插入数据 4.2 查询数据 4.3 更新数据 4.3.1 更新一条数据 4.3.2 更新多条数据 4.4 删除数据 5. 计数、排序、偏移 5.1 计数 5.2 排序 5.3 …...

什么是服务级别协议(SLA)?

在数字化时代&#xff0c;企业和服务提供商之间的关系变得越来越复杂&#xff0c;而服务级别协议&#xff08;SLA&#xff09;则在这个复杂网络中发挥着至关重要的作用。本文将深入介绍SLA&#xff0c;从它的定义、应用场景到监测方法&#xff0c;全方位解析这一法律桥梁如何确…...

使用Python进行Sentinel-2 图像聚类

聚类或无监督分类是根据统计相似性将图像的像素值分组或聚合到一定数量的自然类(组)的过程。在本教程中,我们将使用rasterio进行sentinel-2图像处理,并使用功能强大的完整scikit-learn python 包在jupyter Notebook中进行聚类。 Scikit-learn是一个用于 Python 编程语言的…...

SNZ资本的首席信息官Gavin确认出席Hack .Summit() 2024香港开发者大会!

SNZ资本的首席信息官Gavin确认将出席由 Hack VC 主办&#xff0c;并由 AltLayer 和 Berachain 联合主办&#xff0c;与 SNZ 和数码港合作&#xff0c;由 Techub News 承办的Hack.Summit() 2024区块链开发者盛会。 Gavin是SNZ控股和SNZ资本的首席信息官。Gavin在区块链和金融科技…...

js里面有引用传递吗?

一&#xff1a;什么是引用传递 引用传递是相对于值传递的。那什么是值传递呢&#xff1f;值传递就是在传递过程中再复制一份&#xff0c;然后再赋值给变量&#xff0c;例如&#xff1a; let a 2; let b a;在这个代码中&#xff0c;let b a; 就是一个值传递&#xff0c;首先…...

C 语言 math.h 库介绍

在 C 语言中&#xff0c;math.h 头文件定义了各种数学函数和一个宏&#xff0c;用于处理数学运算。这些函数接受 double 类型的参数&#xff0c;并返回 double 类型的结果。 库宏 在 math.h 中定义了唯一的一个宏&#xff1a; HUGE_VAL&#xff1a;当函数的结果不可表示为浮…...

Eigen-Matrix矩阵

Eigen-Matrix矩阵 一、概述二、矩阵的前三个模板参数三、向量四、动态维度参数五、构造函数六、索引访问器七、逗号初始化八、矩阵维度调整九、赋值和调整大小十、固定尺寸vs.动态尺寸十一、可选模板参数十二、方便预定义 一、概述 在Eigen中&#xff0c;所有矩阵和向量都是矩…...

蓝桥杯14届计算思维国赛U8组包含真题和答案

十四届蓝桥杯国赛考试计算思维 U8 组 答案在底部 第一题 以下选项中,( )是由美国计算机协会设立,对在计算机领域内作出重要贡献的个人授予的奖项 。A.图灵奖 C.菲尔兹奖 B.诺贝尔奖 D.普利策奖 第二题 希希去吃寿司。餐台上摆出了许多食物,可供大家自选。如下图所示。 …...

opencv内存溢出del释放变量 (python)

报错&#xff1a; cv2.error: OpenCV(3.4.17) D:\a\opencv-python\opencv-python\opencv\modules\core\src\alloc.cpp:73: error: (-4:Insufficient memory) Failed to allocate 12211548 bytes in function ‘cv::OutOfMemoryError’ 检查内存代码 import psutil# 获取当前进…...

【算法与数据结构】复杂度深度解析(超详解)

文章目录 &#x1f4dd;算法效率&#x1f320; 算法的复杂度&#x1f320; 时间复杂度的概念&#x1f309;大O的渐进表示法。 &#x1f320;常见复杂度&#x1f320;常见时间复杂度计算举例&#x1f309;常数阶O(1)&#x1f309;对数阶 O(logN)&#x1f309;线性阶 O(N)&#x…...

Upload-Labs-Linux1【CTF】

拿到这道题目一看&#xff0c;发现是upload靶场&#xff1b;这不简简单单吗&#xff1b;结果中间还是遇到了一些小问题 小坑总结&#xff1a;该关只识别标准php语法&#xff1a;<?php phpinfo()?>格式&#xff1b;即<?php ?> 不识别<? phpinfo()?> &…...

搜维尔科技:OptiTrack 提供了性能最佳的动作捕捉平台

OptiTrack 动画 我们的 Prime 系列相机和 Motive 软件相结合&#xff0c;产生了世界上最大的捕获量、最精确的 3D 数据和有史以来最高的相机数量。OptiTrack 提供了性能最佳的动作捕捉平台&#xff0c;具有易于使用的制作工作流程以及运行世界上最大舞台所需的深度。 无与伦比…...

java设计模式之职责链模式

基本介绍 职责链模式&#xff08;Chain of Responsibility Pattern&#xff09;为请求创建了一个接收者对象的链。这种模式对请求的发送者和接收者进行解耦。职责链模式 又叫责任链模式&#xff0c;通常每个接收者都包含对另一个接收者的引用。如果一个对象不能处理该请求。那…...

连不上网的解决办法集--持续更新

连不上网的解决办法集–持续更新 1、有网卡&#xff0c;但网卡驱动失效 背景&#xff1a;有网络驱动但是依旧连不上网&#xff0c;只有inteV6有值&#xff0c;inte 没有值&#xff08;正常应该有个ipv4的信息&#xff09; 判断原因&#xff1a;可能是之前格式化磁盘驱动的时…...

Unity之PUN2插件实现多人联机射击游戏

目录 &#x1f4d6;一、准备工作 &#x1f4fa;二、UI界面处理 &#x1f4f1;2.1 登录UI并连接PUN2服务器 &#x1f4f1;2.2 游戏大厅界面UI &#x1f4f1;2.3 创建房间UI &#x1f4f1;2.4 进入房间UI &#x1f4f1;2.5 玩家准备状态 &#x1f4f1;2.6 加载战斗场景…...

72_Pandas.DataFrame保存并读取带pickle的系列(to_pickle、read_pickle)

72_Pandas.DataFrame保存并读取带pickle的系列&#xff08;to_pickle、read_pickle&#xff09; 要将 pandas.DataFrame、pandas.Series 对象保存为 pickle 文件&#xff0c;请使用 to_pickle() 方法&#xff0c;并使用 pd.read_pickle() 函数读取保存的 pickle 文件。 在此对…...

Redis哨兵模式和Redis Cluster模式

文章目录 &#x1f50a;博主介绍&#x1f964;本文内容Redis Cluster 模式支持自动故障转移功能吗&#xff1f;Redis Cluster 模式支持自动故障转移功能和哨兵有什么区别&#xff1f;Redis Cluster 模式和哨兵模式&#xff08;Sentinel&#xff09;在自动故障转移方面有一些关键…...

C语言第三十二弹---自定义类型:联合和枚举

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】 目录 1、联合体 1.1、联合体类型的声明 1.2、联合体的特点 1.3、相同成员的结构体和联合体对比 1.4、联合体大小的计算 1.5、联合的⼀个练习 2、枚举类型 …...

milvus upsert流程源码分析

milvus版本:v2.3.2 整体架构: Upsert 的数据流向: 1.客户端sdk发出Upsert API请求。 import numpy as np from pymilvus import (connections,Collection, )num_entities, dim 4, 3print("start connecting to Milvus") connections.connect("default",…...

QT网络通信

九、网络 基础概念 1.1 TCP/UDP TCP/UDP UDP TCP 协议相同点&#xff1a;都存在于传输层&#xff0c;全双工通信 TCP&#xff1a;全双工通信、面向连接、可靠 TCP&#xff08;即传输控制协议&#xff09;&#xff1a;是一种面向连接的传输层协议&#xff0c;它能提供高可靠性通…...

遥感领域研究生投稿指南:如何根据2021-2022年JCR/中科院分区快速锁定目标期刊

遥感领域研究生投稿指南&#xff1a;数据驱动的期刊选择策略 第一次投稿就像在陌生的城市找路——手里有地图&#xff0c;但每条街看起来都差不多。去年这个时候&#xff0c;我盯着二十多个遥感期刊的分区数据发愁&#xff0c;直到导师点醒我&#xff1a;"分区不是用来膜…...

从单根谱线到频谱搬移:用Matlab的fft/pspectrum搞懂实信号与复信号频谱差异

从单根谱线到频谱搬移&#xff1a;用Matlab的fft/pspectrum搞懂实信号与复信号频谱差异 第一次用Matlab的fft函数画正弦信号频谱时&#xff0c;我盯着屏幕上对称的两根谱线愣了半天——明明只生成了一个频率的正弦波&#xff0c;为什么会出现两根线&#xff1f;直到后来接触复信…...

别再被EMI困扰了!手把手教你理解并配置PCIE/SATA/USB3.0的SSC扩频时钟

高速接口EMI实战指南&#xff1a;SSC扩频时钟配置与参数优化 在硬件工程师的日常工作中&#xff0c;电磁干扰&#xff08;EMI&#xff09;问题就像一位不请自来的"隐形访客"&#xff0c;总是在产品认证测试的关键时刻突然出现。特别是面对PCIE、SATA、USB3.0这类高速…...

终极文档下载指南:30+平台一键下载,告别繁琐流程轻松保存学习资料

终极文档下载指南&#xff1a;30平台一键下载&#xff0c;告别繁琐流程轻松保存学习资料 【免费下载链接】kill-doc 看到经常有小伙伴们需要下载一些免费文档&#xff0c;但是相关网站浏览体验不好各种广告&#xff0c;各种登录验证&#xff0c;需要很多步骤才能下载文档&#…...

从《新概念英语》Lesson 21-30 看技术人的沟通困境:当你的代码像‘飞机噪音’一样让人抓狂

技术协作中的"噪音治理"&#xff1a;从代码可读性到团队沟通的降噪实践 深夜的办公室里&#xff0c;键盘敲击声此起彼伏。工程师Tom盯着屏幕上同事提交的代码变更&#xff0c;眉头越皱越紧——没有注释的复杂逻辑、随意命名的变量、嵌套五层的条件判断&#xff0c;这…...

从防御者视角复盘:如何用Burp Suite和代码审计,在Pikachu靶场中挖掘并修复DOM-XSS漏洞

防御视角实战&#xff1a;基于Burp Suite与代码审计的DOM-XSS漏洞挖掘与修复指南 在当今Web应用安全领域&#xff0c;DOM型XSS&#xff08;跨站脚本&#xff09;漏洞因其独特的客户端特性&#xff0c;往往成为传统安全防护体系的盲区。与传统的反射型或存储型XSS不同&#xff0…...

WebLaTeX:免费在线LaTeX编辑器的终极解决方案,告别复杂安装的学术写作新体验

WebLaTeX&#xff1a;免费在线LaTeX编辑器的终极解决方案&#xff0c;告别复杂安装的学术写作新体验 【免费下载链接】WebLaTex A complete alternative for Overleaf with VSCode Web Git Integration Copilot Grammar & Spell Checker Live Collaboration Support. …...

OpenLayers实战:5分钟搞定天地图WMTS与XYZ加载(附完整代码)

OpenLayers实战&#xff1a;5分钟搞定天地图WMTS与XYZ加载&#xff08;附完整代码&#xff09; 第一次接触天地图服务时&#xff0c;我被它丰富的图层类型和稳定的服务所吸引&#xff0c;但在集成过程中却踩了不少坑。作为国内最权威的在线地图服务之一&#xff0c;天地图同时支…...

nSkinz:CS:GO终极皮肤修改器完整指南

nSkinz&#xff1a;CS:GO终极皮肤修改器完整指南 【免费下载链接】nSkinz Skin changer for CS:GO 项目地址: https://gitcode.com/gh_mirrors/ns/nSkinz 想要在CS:GO中自由更换武器皮肤却不想花费大量金钱&#xff1f;nSkinz开源皮肤修改器为你提供了完美的解决方案。这…...

PyTorch加载.pth预训练模型,别再傻傻等下载了!手把手教你三种离线下载方法

PyTorch预训练模型离线加载实战指南&#xff1a;突破网络限制的三种高效方案 当你兴奋地敲下pretrainedTrue准备加载ResNet模型时&#xff0c;那个熟悉的红色报错又一次出现在屏幕上——连接超时。国内开发者使用PyTorch时最头疼的问题之一&#xff0c;就是无法稳定下载官方预训…...