Mongodb基础用法【总结】

关系型数据库和非关系型数据库的区别

关系型数据库

1.在关系型数据库中,数据都是存储在表中的,对存储的内容有严格的要求

2.因为我们在创建表的时候久已经规定了表中的字段 存储的数据类型 是否为空 唯一标识等规则

3.由于操作的都是结构化的数据,所以我们需要使用结构化语言sql来操作
非关系型数据库

1.没有表概念 所以存储数据更加灵活 不规定字段 数据类型 是否为空 唯一标识等

2.由于数据没有严格要求,所以无需食用sql来操作

在mongodb中我们存储的数据是一个类似于json的格式叫BSON 例如 {name:wyf,age:18,sex:1}

高并发 高性能 高可用

拓展性强 不需要指定列

mongodb的缺点 对事务的支持不是很友好

mongodb中记录的就是一个文档 一个数据库中有多个集合 每个集合包含多个文档 域(就是字段) Mongodb通过嵌入式文档来代替多表联查

mongodb的基础常用命令

show dbs查询所有库 mongodb存储分为两部分 上面是内存 下面是磁盘 当我们用use 创建库的时候 我们的库现在在内存中 没有持久化到磁盘 当我们新建的库有一个文档数据的时候 就会自动存如磁盘中

mongodb默认的3个库

1.admin 就是用来存储用户信息的库

2.local这个库的数据永远不会被复制,可以用来存储先于本地单台服务器的任意集合

3.config 当mongodb用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。

创建数据库

use [数据库名称] 如果use没有这个数据库就会创建一个 如果有那就切换到这个数据库

文档类似于mysql的一行数据

集合类似于mysql的table

数据库的删除

db.dropDatabase()

创建集合(集合就相当于mysql中的表)
显示创建

db.createCollection("集合名称") 不管里面是否有文档 先把这个集合创建出来
隐式创建

插入文档的时候 集合如果不存在 则创建集合

删除集合

db.集合名称.drop() 返回true就代表删除成功

插入文档

单条

db.集合名称.insert({})

多条

db.集合名称.insertMany({})

如果没有这个集合名称 就会被隐式创建

如果某一条数据插入失败就比较麻烦 我们想要找到具体的报错可以使用 try catch机制

1.try 将可能抛出异常的代码放在try中

2.catch 如果try块中的代码抛出异常,catch块将捕获这个异常,并允许定义错误处理逻辑

查询所有

db.集合名称.find()

查询指定的数据

db.集合名称.find({"":""})

查询第一条数据

db.集合名称.findOne({"":""})

投影查询 (只想显示部分的字段)

db.集合名称.find({"id":"1"},{"id":"1"})

这样就只会显示我们的id字段

文档更新

覆盖修改

db.集合名称.update({_id:"1"},{"要修改的字段":"修改内容"})

如何这种方法 会把之前的文档数据全部修改

局部修改

db.集合名称.update({_id:"2"},{$set:{"修改字段":"修改内存"}})

这种方法更改指定字段并保留其他数据

批量修改

db.集合名称.update({_id:"2"},{$set:{"修改字段":"修改内存"}},{multi:true})就是批量修改符合类型的文档

最新的mongodb中支持updateMany的函数可以直接修改批量数据

列值增长修改

db.集合名称.update({_id:""},{$inc:{要增长的字段:1}})

代表这个字段每次增长1 _id后面的值是字符串 例如 【增长字段开始为666】增长完就是667

删除文档

db.集合名称.remove({"要删除的文档字段":"条件"})

全部删除

db.集合名称.remove({不加条件})

分页查询

1.统计数据

db.collection.count() //查询所有

db.collection.count({"":""}) //查询指定条件数量

2.显示指定条数

db.comment.find().limit()

3.跳过某些数据进行查询

db.comment.find().limit().skip(从第几条跳过)

4.排序

db.comment.find().sort({"条件字段":"1"}) 1代表升序 -1代表降序

比较复制的查询

通过正则的形式实现模糊查询

1.db.comment.find({"字段":/条件/})

mongodb复制的正则也可也接收

大于某条件

2.db.集合名称.find({条件字段:{KaTeX parse error: Expected 'EOF', got '}' at position 18: ...:NumberInt(700)}̲}) ![在这里插入图片描述]...in:["1003"]})

里面是个数组 可以包含多个条件

条件查询

and或者or

db.集合名称.find({KaTeX parse error: Expected '}', got 'EOF' at end of input: and:[{字段:NumberInt(700)},{字段:{KaTeX parse error: Expected 'EOF', got '}' at position 19: ...NumberInt(2000)}̲}]}) 点赞数大于700 小...or:[{字段:"条件"},{"字段":"条件"}])

索引-Index

mongodb的索引使用的是B-Tree
单字段索引

在某一字段查询添加索引, 假如添加的字段值为30 那么先查询到索引的30 在通过30找到该集合
复合索引

列出的字段顺序具有重要意义,例如符合索引由(userid:1,score:-1)组成,则索引首先按userid正序排序,然后在内个userid的值内,再在按score倒序排序。

相关推荐
·薯条大王2 小时前
MySQL联合查询
数据库·mysql
morris1314 小时前
【redis】redis实现分布式锁
数据库·redis·缓存·分布式锁
hycccccch4 小时前
Canal+RabbitMQ实现MySQL数据增量同步
java·数据库·后端·rabbitmq
这个懒人5 小时前
深入解析Translog机制:Elasticsearch的数据守护者
数据库·elasticsearch·nosql·translog
Yan-英杰5 小时前
【百日精通JAVA | SQL篇 | 第二篇】数据库操作
服务器·数据库·sql
NineData6 小时前
NineData云原生智能数据管理平台新功能发布|2025年3月版
数据库
百代繁华一朝都-绮罗生7 小时前
检查是否存在占用内存过大的SQL
数据库·sql
吾日三省吾码7 小时前
Python 脚本:自动化你的日常任务
数据库·python·自动化
CZIDC7 小时前
win11 系统环境下 新安装 WSL ubuntu + ssh + gnome 桌面环境
数据库·ubuntu·ssh
直裾7 小时前
Mapreduce的使用
大数据·数据库·mapreduce