MongoDB 配合python使用的入门教程

MongoDB 入门教程

1. 安装 MongoDB

首先,你需要在你的机器上安装MongoDB。你可以从 MongoDB官网 下载并安装 Community 版本。安装完成后,启动MongoDB服务。

python 复制代码
# 在Linux/Mac上启动MongoDB
mongod

# 在Windows上,你可以通过Windows服务启动MongoDB
2. 安装 Python 和 Pymongo

确保你的机器上已经安装了Python。可以使用 pip 安装 pymongo,这是MongoDB的Python驱动程序。

python 复制代码
pip install pymongo
3. 连接到 MongoDB

以下是如何使用Python连接到MongoDB的示例代码。

python 复制代码
import pymongo

# 创建MongoDB客户端
client = pymongo.MongoClient("mongodb://localhost:27017/")

# 选择数据库
db = client["mydatabase"]

# 选择集合
collection = db["mycollection"]

print("连接成功!")
4. 插入数据

你可以使用以下代码插入文档到集合中。

python 复制代码
# 插入单个文档
document = {"name": "Alice", "age": 25}
collection.insert_one(document)

# 插入多个文档
documents = [
    {"name": "Bob", "age": 30},
    {"name": "Charlie", "age": 35}
]
collection.insert_many(documents)

print("数据插入成功!")
5. 查询数据

可以使用以下代码查询集合中的数据。

python 复制代码
# 查询单个文档
single_document = collection.find_one({"name": "Alice"})
print("查询到的单个文档:", single_document)

# 查询多个文档
all_documents = collection.find()
print("查询到的所有文档:")
for doc in all_documents:
    print(doc)
6. 更新数据

你可以使用以下代码更新已有文档。

python 复制代码
# 更新单个文档
collection.update_one({"name": "Alice"}, {"$set": {"age": 26}})

# 更新多个文档
collection.update_many({"age": {"$gte": 30}}, {"$set": {"status": "senior"}})

print("数据更新成功!")
7. 删除数据

可以使用以下代码删除集合中的文档。

python 复制代码
# 删除单个文档
collection.delete_one({"name": "Alice"})

# 删除多个文档
collection.delete_many({"age": {"$lt": 30}})

print("数据删除成功!")
8. 清理和关闭连接

使用完成后,可以清理数据并关闭连接。

python 复制代码
# 清空集合
collection.delete_many({})

# 关闭连接
client.close()
print("MongoDB连接已关闭。")

总结

现在你已经掌握了如何在Python中使用MongoDB进行基本的操作。你可以根据自己的需求扩展这个简单的示例。MongoDB有很多强大的特性,比如索引、聚合管道和更复杂的查询,你可以进一步查询其文档以了解更多。

相关推荐
数据库小组6 小时前
2026 年,MySQL 到 SelectDB 同步为何更关注实时、可观测与可校验?
数据库·mysql·数据库管理工具·数据同步·ninedata·selectdb·迁移工具
华科易迅6 小时前
MybatisPlus增删改查操作
android·java·数据库
Kethy__6 小时前
计算机中级-数据库系统工程师-计算机体系结构与存储系统
大数据·数据库·数据库系统工程师·计算机中级
SHoM SSER6 小时前
MySQL 数据库连接池爆满问题排查与解决
android·数据库·mysql
熬夜的咕噜猫7 小时前
MySQL备份与恢复
数据库·oracle
jnrjian7 小时前
recover database using backup controlfile until cancel 假recover,真一致
数据库·oracle
lifewange8 小时前
java连接Mysql数据库
java·数据库·mysql
大妮哟8 小时前
postgresql数据库日志量异常原因排查
数据库·postgresql·oracle
还是做不到嘛\.9 小时前
Dvwa靶场-SQL Injection (Blind)-基于sqlmap
数据库·sql·web安全
不写八个9 小时前
PHP教程004:php链接mysql数据库
数据库·mysql·php