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倒序排序。

相关推荐
尘浮生1 小时前
Java项目实战II基于Spring Boot的美食烹饪互动平台的设计与实现(开发文档+数据库+源码)
java·开发语言·数据库·spring boot·微信小程序·小程序·美食
forestqq1 小时前
构建后端为etcd的CoreDNS的容器集群(七)、编写适合阅读的域名管理脚本
运维·数据库·etcd
hongkid1 小时前
MongoDB常用操作
数据库·mongodb
岁岁岁平安2 小时前
mysql上课总结(1)(mysql中的常见的存储引擎)(面试)
数据库·mysql·innodb·存储引擎
幽兰的天空3 小时前
python实现excel数据导入数据库
数据库
尘佑不尘4 小时前
shodan5,参数使用,批量查找Mongodb未授权登录,jenkins批量挖掘
数据库·笔记·mongodb·web安全·jenkins·1024程序员节
传输能手4 小时前
从三方云服务器将数据迁移至本地,如何保障安全高效?
大数据·服务器·数据库
BinTools图尔兹5 小时前
CQ社区版 v2024.10 | 支持k8s、helm部署!
数据库·安全·k8s·helm·数据安全·数据库管理员
北笙··5 小时前
Redis慢查询分析优化
数据库·redis·缓存
p-knowledge5 小时前
redis的三种客户端
数据库·redis·缓存