mongoDB快速上手

MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。

MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组,

下载https://www.mongodb.com/try/download/community

下载完成解压缩

在目下创建data/db文件夹

创建logs/mongo.log

创建mongo.config

python 复制代码
dbpath=D:\mongodb-win32-x86_64-windows-7.0.5\data #数据库路径
logpath=D:\mongodb-win32-x86_64-windows-7.0.5\logs\mongo.log #日志输出文件路径
port=27017 #端口号默认为27012

添加环境变量

安装服务

python 复制代码
mongod --config D:\mongodb-win32-x86_64-windows-7.0.5\mongo.config --install --serviceName "mongodb"

打开Windows PowerShell执行命令

启动服务

python 复制代码
mongod --dbpath D:\mongodb-win32-x86_64-windows-7.0.5\data

mongodb增删改查

文档 :文档相当于mysql中的一行,就是一句JSON键值对

集合:多个文档组成一个集合

数据库:多个集合组成一个数据库

展示数据库

show dbs

创建数据库

插入数据

插入数据

python 复制代码
db.xw.insert({data:"2024"})
多条
db.xw.insertMany({}{})

读取数据

python 复制代码
db.xw.findOne()或find()  加pretty()可以美化打印

更新数据

python 复制代码
db.xw.updata({data:"2024"},{data:"2222"})

删除数据

python 复制代码
db.xw.remove({data:"2024"})

删除集合

python 复制代码
db.xw.drop()

MongoDB的ID

MongoDB的每一条文档插入都会有一个默认ID,而且必须存在

属于Objectid这个默认类型,有12字节存储空间,共24个十六进制数字

查询

默认返回当前集合的所有数据

python 复制代码
db.xw.find({})

查询url小于等于10的

python 复制代码
db.xw.find({url:{$lte:10}})
lt 小于
ge 大于
gte 大于等于

查询url是否存在 1 3 4

python 复制代码
db.xw.find({url:{$in:[1,3,4]}})
nin不存在

存在id的

python 复制代码
db.xw.find(id:{$exists:true}})

不显示_id,显示url数据

python 复制代码
db.xw.find({},{_id:0,url:1})

Python操作MongoDB

安装包

python 复制代码
pip install pymongo
python 复制代码
import pymongo
#连接
client=pymongo.MongoClient("mongodb://127.0.0.1:27017")

#数据库
db=client['xw']
#集合
col=db['test']

mydict={"name":"python"}

#插入数据
res=col.insert_one(mydict)
print(res)


# mylist=[
#     {"name":"C++"},{"name":"Lua"}
# ]
# # res=col.insert_many(mylist)
# # print(res)
# for num,i in enumerate(mylist):
#     i['id']=num
#     col.insert_one(i)
## 查找数据
# res=col.find({},{"_id":0})
# for r in res:
#     print(r)
#更新
col.update_one(mydict,{"$set":{"name":"python3"}})
#删除
col.delete_many({})
相关推荐
Agent手记7 小时前
安全生产巡检全流程自动化与隐患预警方案:2026工业Agent落地实战指南
数据库·人工智能·安全·ai·自动化
whn19777 小时前
查询日期报错,参数DATETIME_FMT_MODE
数据库·sql
Gauss松鼠会8 小时前
GaussDB(DWS) GUC参数修改、查看
java·数据库·sql·数据库开发·gaussdb
米高梅狮子8 小时前
Ceph 分布式存储 部署
linux·运维·数据库·分布式·ceph·docker·华为云
滴滴答答哒8 小时前
.NET Core 基于 AOP + Polly 实现数据库死锁自动重试
数据库·.netcore·sqlsugar
yuzhiboyouye8 小时前
所有的 SQL 都要经过 Explain 优化,是什么意思
数据库·sql
洛水水9 小时前
Redis 实现限流功能的几种方法
数据库·redis·缓存
l1t9 小时前
DeepSeek总结的postgresql 数据分析师 vs width_bucket()
数据库·postgresql
米高梅狮子9 小时前
Redis
数据库·redis·mysql·缓存·docker·容器·github
dinl_vin9 小时前
FastAPI 系列 ·(四):数据库集成——SQLAlchemy 2.0 异步 ORM 与 Alembic 迁移
java·数据库·fastapi