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({})
相关推荐
睡觉的时候不会困3 小时前
Redis 主从复制详解:原理、配置与主从切换实战
数据库·redis·bootstrap
程序员的世界你不懂5 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
自学也学好编程5 小时前
【数据库】Redis详解:内存数据库与缓存之王
数据库·redis
JAVA不会写6 小时前
在Mybatis plus中如何使用自定义Sql
数据库·sql
IT 小阿姨(数据库)6 小时前
PgSQL监控死元组和自动清理状态的SQL语句执行报错ERROR: division by zero原因分析和解决方法
linux·运维·数据库·sql·postgresql·centos
ChinaRainbowSea6 小时前
7. LangChain4j + 记忆缓存详细说明
java·数据库·redis·后端·缓存·langchain·ai编程
小马学嵌入式~7 小时前
嵌入式 SQLite 数据库开发笔记
linux·c语言·数据库·笔记·sql·学习·sqlite
Java小白程序员8 小时前
MyBatis基础到高级实践:全方位指南(中)
数据库·mybatis
Monly218 小时前
人大金仓:merge sql error, dbType null, druid-1.2.20
数据库·sql
不宕机的小马达8 小时前
【Mysql|第一篇】Mysql的安装与卸载、Navicat工具的使用
数据库·mysql