
来源:Python爬虫与数据挖掘
作者:Python进阶者
大家好,我是Python进阶者。
作为非关系数据库的代表--Mongo,可以说是让人又爱又恨,让人爱的是它的便捷性,让人恨的是它的配置,实在是坑多。那么今天我们就来深入剖析它吧。
pip install pymongo from pymongo import MongoClient
1.普通登录,又称游客登陆,安全等级低
MongoClient('mongodb://localhost:27017/')
2.用户密码登陆,安全等级高
MongoClient('mongodb://hwzjj:123456@localhost:27017/hw')
这里连接到了用户名为hwzjj,密码为123456的用户。
为了安全,我们使用用户名和密码登陆,然后创建一个集合,不知道大家对Mongo创建集合还有没有印象,反正小编还有,废话不多说,先创建两个集合。
db.createCollection(name='student',option={capped:true,autoIndexId:true,size:100,max:1000}) db.createCollection(name='teacher',option={capped:true,autoIndexId:true,size:200,max:2000})
这样就创建了一student和teacher的集合了。然后我们再来显示一下所有的集合名:
show collections;
然后我们往集合里插入数据,在Mongo中是这样插入的:
可以看到我们成功插入了两条数据,接下来我们利用Python来插入数据。
1.直接使用创建好的集合插入数据
from pymongo import MongoClient
client=MongoClient('mongodb://hwzjj:123456@localhost:27017/hw') 连接数据库
db=client['hw'] 选择数据库hw
coll=db['student'] 选择集合
res={'id':'0003','name':'任性','age':43}
first=coll.insert_one(res) 将数据插入到集合中 print(first.inserted_id) 打印插入数据的id(每个插入数据都会有)
2.自己创建集合插入数据
from pymongo import MongoClient
client=MongoClient('mongodb://hwzjj:123456@localhost:27017/hw')
db=client['hw']
db.create_collection('teacher') 创建集合
res={'id':'0001','name':'boy','age':36}
last=db.student.insert_one(res) 插入数据 print(last.inserted_id) 打印id
3.插入多条数据
import random
from pymongo import MongoClient
client=MongoClient('mongodb://hwzjj:123456@localhost:27017/hw')
db=client['hw']
coll=db['student'] def get(): for y in range(100000):
data={'id':y,'name':'user--'+str(y),'age':random.choice(range(100))} yield data for y in get():
coll.insert(y)
同样是插入十万个数据, 不过数据却是比Mysql慢一点,可自行测试。
注:执行插入操作时,Insert最多可插入四条同样的记录。
仍旧是先要获取集合,然后对集合中的内容进行修改。
1.更新匹配到的第一条数据
from pymongo import MongoClient
client=MongoClient('mongodb://hwzjj:123456@localhost:27017/hw')
db=client['hw']
coll=db['student']
coll.update_one({'name':'user--10'},{'$set':{'name':'用户已注销'}}) 更新匹配到的第一条数据
2.更新匹配到的所有数据
我们创建四个一样的数据,将程序执行四次即可:
from pymongo import MongoClient
client=MongoClient('mongodb://hwzjj:123456@localhost:27017/hw')
db=client['hw']
coll=db['student']
coll.insert({'id':'111','name':'hw','age':43})
可以看到生成了四个同样的记录,当然了,只能生成最多4条记录。然后我们全部将它们数据修改。
coll.update({'name':'hw'},{'$set':{'name':'用户已注册'}})
1.删除所有符合条件的数据
from pymongo import MongoClient
client=MongoClient('mongodb://hwzjj:123456@localhost:27017/hw')
db=client['hw']
coll=db['student']
coll.insert({'id':'111','name':'hw','age':43}) 插入数据
coll.remove({'name':'hw'}) 删除所有name 为hw的数据,注意不要以id为条件来删除,会报错
coll.delete_many({'name':'hw'}) 跟上者功能一样
2.删除所有符合条件的第一条数据
from pymongo import MongoClient
client=MongoClient('mongodb://hwzjj:123456@localhost:27017/hw')
db=client['hw']
coll=db['student']
coll.insert({'id':'111','name':'hw','age':43})
coll.delete_one({'name':'hw'}) 删除符合条件的第一条数据
1.查询符合条件的第一条数据
2.查询符合条件的所有数据
3.查找后删除
4.查找后替换
5.查找后更新
6.统计符合条件的记录数量
coll.find().count() # 记录符合条件的数量
7.符合条件的数据的排序
coll.find().sort('name', pymongo.ASCENDING) # 升序排序 DESCENDING 降序排序
8.符合条件数量中跳过
coll.find().sort('name', pymongo.ASCENDING).skip(1) # 跳过一个记录
9.限制符合条件输出数量
coll.find().sort('name', pymongo.ASCENDING).limit(2) # 输出两个符合条件的记录
10.通过Id来查找
每个插入的数据都会生成一个id,貌似被加密了,前面我们已经和它打过交道了,下面来看下它的使用。
from bson.objectid import ObjectId
find_one({'_id': ObjectId(id_name)})
1.创建索引
可以看到有两个索引,一个是Mongo自动创建的在id上的索引,另一个是刚刚创建在name上的索引。
2.获取索引
for y in coll.list_indexes(): # 获取所有索引 print(y)
3.删除索引
可以看到刚刚的索引name已经被删除了,而且只有一条数据了,那么有人就问了,为何不把_id一起删除,很抱歉,这个是删不了的。
通过本章对Pymongo的学习,相信你已经可以胜任日常一些开发了,Pymongo中还有很多值得学习的地方,值得你去推敲,在这里就不一一列举了,希望本文能带大家零基础毫无压力入门Pymongo。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
PyTorch 核心机制:损失函数与反向传播如何驱动模型进化 在深度学习的世界里,模型从 “一无所知” 到 “精准预测” 的蜕变,离 ...
2025-07-252025 年 CDA 数据分析师考纲焕新,引领行业人才新标准 在数字化浪潮奔涌向前的当下,数据已成为驱动各行业发展的核心要素。作为 ...
2025-07-25从数据到决策:CDA 数据分析师如何重塑职场竞争力与行业价值 在数字经济席卷全球的今天,数据已从 “辅助工具” 升级为 “核心资 ...
2025-07-25用 Power BI 制作地图热力图:基于经纬度数据的实践指南 在数据可视化领域,地图热力图凭借直观呈现地理数据分布密度的优势,成 ...
2025-07-24解析 insert into select 是否会锁表:原理、场景与应对策略 在数据库操作中,insert into select 是一种常用的批量数据插入语句 ...
2025-07-24CDA 数据分析师的工作范围解析 在数字化时代的浪潮下,数据已成为企业发展的核心资产之一。CDA(Certified Data Analyst)数据分 ...
2025-07-24从 CDA LEVEL II 考试题型看 Python 数据分析要点 在数据科学领域蓬勃发展的当下,CDA(Certified Data Analyst)认证成为众多从 ...
2025-07-23用 Python 开启数据分析之旅:从基础到实践的完整指南 在数据驱动决策的时代,数据分析已成为各行业不可或缺的核心能力。而 Pyt ...
2025-07-23鸢尾花判别分析:机器学习中的经典实践案例 在机器学习的世界里,有一个经典的数据集如同引路明灯,为无数初学者打开了模式识别 ...
2025-07-23解析 response.text 与 response.content 的核心区别 在网络数据请求与处理的场景中,开发者经常需要从服务器返回的响应中提取数 ...
2025-07-22解析神经网络中 Softmax 函数的核心作用 在神经网络的发展历程中,激活函数扮演着至关重要的角色,它们为网络赋予了非线性能力, ...
2025-07-22CDA数据分析师证书考取全攻略 一、了解 CDA 数据分析师认证 CDA 数据分析师认证是一套科学化、专业化、国际化的人才考核标准, ...
2025-07-22左偏态分布转正态分布:方法、原理与实践 左偏态分布转正态分布:方法、原理与实践 在统计分析、数据建模和科学研究中,正态分 ...
2025-07-22你是不是也经常刷到别人涨粉百万、带货千万,心里痒痒的,想着“我也试试”,结果三个月过去,粉丝不到1000,播放量惨不忍睹? ...
2025-07-21我是陈辉,一个创业十多年的企业主,前半段人生和“文字”紧紧绑在一起。从广告公司文案到品牌策划,再到自己开策划机构,我靠 ...
2025-07-21CDA 数据分析师的职业生涯规划:从入门到卓越的成长之路 在数字经济蓬勃发展的当下,数据已成为企业核心竞争力的重要来源,而 CD ...
2025-07-21MySQL执行计划中rows的计算逻辑:从原理到实践 MySQL 执行计划中 rows 的计算逻辑:从原理到实践 在 MySQL 数据库的查询优化中 ...
2025-07-21在AI渗透率超85%的2025年,企业生存之战就是数据之战,CDA认证已成为决定企业存续的生死线!据麦肯锡全球研究院数据显示,AI驱 ...
2025-07-2035岁焦虑像一把高悬的利刃,裁员潮、晋升无望、技能过时……当职场中年危机与数字化浪潮正面交锋,你是否发现: 简历投了10 ...
2025-07-20CDA 数据分析师报考条件详解与准备指南 在数据驱动决策的时代浪潮下,CDA 数据分析师认证愈发受到瞩目,成为众多有志投身数 ...
2025-07-18