python中MongoDB操作实践:查询文档、批量插入文档、更新文档、删除文档

MongoDB操作实践:查询文档

python 复制代码
from pymongo import MongoClient

# 连接本地MongoDB,默认端口 27017
client = MongoClient('localhost', 27017)

# 创建数据库/选择数据库 (字典类型的操作)
db = client['test_db']

# 创建数据表/数据集合
collection = db['users']

# 查询一个文档 查询的内容依然以 json格式传递,例如{'name':'angle'}
one = collection.find_one({'name': 'angle'})
print(f'find one user:{one}', type(one))

执行结果

查询多个文档

python 复制代码
# 查询多个文档
all_users = collection.find()
for user in all_users:
    print(user)

执行结果

批量插入文档

python 复制代码
from pymongo import MongoClient

# 连接本地MongoDB,默认端口 27017
client = MongoClient('localhost', 27017)

# 创建数据库/选择数据库 (字典类型的操作)
db = client['test_db']

# 创建数据表/数据集合
collection = db['users']

# 插入单个文档-->类似于mysql中一条数据
# user = {'name':'alice', 'age':20, 'email':'vvvvv@com'}  # 字典类型数据/文档型数据(json型数据)
#
# insert_one_result = collection.insert_one(user)

# print(f'inserted_id is:{insert_one_result.inserted_id}')

# 查询一个文档 查询的内容依然以 json格式传递,例如{'name':'angle'}
# one = collection.find_one({'name': 'angle'})
# print(f'find one user:{one}', type(one))



# 批量插入文档
many_users = [{'name':'tom', 'age':23, 'email':'tom@qq.com'},
    {'name':'tina', 'age':28, 'email':'tina@qq.com'},
    {'name':'jay', 'age':32, 'email':'jay@qq.com'}]

insert_many_result = collection.insert_many(many_users)
print('insert_many_ids', insert_many_result.inserted_ids)

# 查询多个文档
all_users = collection.find()
for user in all_users:
    print(user)

执行结果

更新文档

python 复制代码
collection.update_one({'name':'alice'}, {'$set':{'name':'alice', 'age':29}})

更新多条文档

python 复制代码
# 更新多条文档
collection.update_many(
    {'age':{'$lt': 30}},
    {'$set':{'status':'young'}}
)

执行结果见下表,已经给30岁以下的打上了标签

删除文档

删除一条

python 复制代码
collection.delete_one(
    {'name':'tom'}
)


删除多条(条件删除)

python 复制代码
collection.delete_many(
    {'age':{'$gte':23, '$lt':29}}
)


删除所有

python 复制代码
# 删除所有
collection.delete_many({})

执行结果如下

相关推荐
代码中介商13 分钟前
C++ STL 容器完全指南(二):vector 深入与 stringstream 实战
开发语言·c++
阿正的梦工坊4 小时前
深入理解 PyTorch 中的 unsqueeze 操作
人工智能·pytorch·python
FreakStudio5 小时前
硬件版【Cursor】?aily blockly IDE尝鲜封神,实战硬伤尽显
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
郝学胜-神的一滴6 小时前
Qt 入门 01-01:从零基础到商业级客户端实战
开发语言·c++·qt·程序人生·软件构建
测试员周周7 小时前
【Appium 系列】第06节-页面对象实现 — LoginPage 实战
开发语言·前端·人工智能·python·功能测试·appium·测试用例
摇滚侠7 小时前
@Autowired 和 @Resource 的区别
java·开发语言
2301_783848657 小时前
优化文本分类中堆叠模型的网格搜索性能:避免训练卡顿的实战指南
jvm·数据库·python
Wy_编程7 小时前
go语言中的结构体
开发语言·后端·golang
SeaTunnel7 小时前
(八)收官篇 | 数据平台最后一公里:数据集成开发设计与上线治理实战
java·大数据·开发语言·白鲸开源
CLX05058 小时前
如何安装Oracle 12c Cloud Control_OMS服务端组件与Agent部署
jvm·数据库·python