MongoDB
简介:
MongoDB 是一个基于分布式文件存储的数据库;介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。
特点
高性能、易部署、易使用,存储数据非常方便。
主要功能特性有:
- 面向集合存储,易存储对象类型的数据。
- 模式自由。
- 支持动态查询。
- 支持完全索引,包含内部对象。
- 支持查询。
- 支持复制和故障恢复。
- 使用高效的二进制数据存储,包括大型对象(如视频等)。
- 自动处理碎片,以支持云计算层次的扩展性。
- 支持RUBY,PYTHON,JAVA,C ,PHP,C#等多种语言。
- 文件存储格式为BSON(一种JSON的扩展)。
- 可通过网络访问。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8g9CyHxe-1596430989479)(D:\Users\Desktop\关于MongoDB.jpg)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Mvrc65Pw-1596430989481)(D:\Users\Desktop\MongoDB vs 关系型数据库.jpg)]
优势:
1.简单直观
以自然的方式来建模,以直观的方式来与数据库交互,采用bson结构存储数据,可以简单理解升级版json格式
2.结构灵活
弹性模式从容响应需求的变更
3.快速开发
做更多的事,写更少的代码
4.原生的高可用与易扩展
单机模式:开始与测试
复制集模式:数据量不大应用, 需要事务支持的应用
分片集群模式: 大数据量应用
应用场景:
游戏场景,社交场景,物联网场景,视频直播
mongodb核心概念
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SvbK1IgN-1596430989483)(D:\Users\Desktop\概念.png)]
文档添加 删除 修改:
db.集合名.insert(文档):往集合中插入一个文档
删除:
db.集合名.remove(
<query>,
{
justOne:<boolean>,
writeConcern:<document>
}
)
分页:
db.集合.find({}).skip(n).limit(m
排序:
db.集合名.find({}).sort({字段:1})//升序
db.集合名.find({}).sort({字段:-1})//降序
数组字段:
db.users.updateMany({}, {$set:{hobby:[]}})
比较运算符:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2XwIDNjY-1596430989486)(D:\Users\Desktop\搜狗截图20200803121152.png)]
逻辑运算查询:
&& 与 - $and
|| 或 - $or
! 非 - $not
语法 -> find( {逻辑操作符: [条件1, 条件2, ...]} )
模糊查询:
{name:/xxx/} —>%xxx%
{name:/^xxx/} —>xxx%
{name:/xxx$/} —>%xxx
{name:/xxx/i} 忽略大小写
db.集合.find({列: {$regex: /关键字/}})
//sql: select * from user where name like '%%'
数组操作的添加,删除,修改:
//$push : 给数组字段添加数据, 允许数据元素重复
db.users.update({name:'dafei'}, {$push:{hobby:'java'}})
//$addToSet: 给数组字段添加数据, 不允许数据元素重复
db.users.update({name:'dafei'}, {$addToSet:{hobby:'java'}})
//$pop 删除数组中数据, 1:删除最后一个, -1: 删除第一个
db.users.update({name:"dafei"},{$pop:{hobby:1}})
$pull 删除数组中数据, 通过指定内容删除
db.users.update({name:'dafei'}, {$pull:{hobby:'java'}}
//通过索引修改
db.users.update({name:'dafei'}, {$set:{'hobby.1':'go'}})
//通过数组元素修改
db.users.update({name:'dafei', hobby:'c'}, {$set:{'hobby.$':'c#'}})
b.users.update({name:‘dafei’}, {KaTeX parse error: Expected 'EOF', got '}' at position 21: …'hobby.1':'go'}}̲) //通过数组元素修改 db…set:{‘hobby.$’:‘c#’}})