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({})
相关推荐
CryptoRzz1 小时前
越南k线历史数据、IPO新股股票数据接口文档
java·数据库·后端·python·区块链
学Java的bb1 小时前
MybatisPlus
java·开发语言·数据库
重生之我要当java大帝1 小时前
java微服务-尚医通-编写医院设置接口上
java·数据库·微服务
Mu.3872 小时前
初始Spring
java·数据库·spring
葡萄城技术团队2 小时前
突破Excel局限!SpreadJS让电子表格“活”起来
java·数据库·excel
J总裁的小芒果2 小时前
SQL Server 报错 当 IDENTITY_INSERT 设置为 OFF 时,不能为表 ‘ORDER_BTN‘ 中的标识列插入显式值
数据库
神的孩子都在歌唱2 小时前
PostgreSQL 向量检索方式(pgvector)
数据库·人工智能·postgresql
数据库那些事儿2 小时前
极智编程:基于Qoder+PolarDB Supabase 实现全栈VibeCoding
数据库
该用户已不存在3 小时前
MySQL 与 PostgreSQL,该怎么选?
数据库·mysql·postgresql