MongoDB的介绍

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介: MongoDB的介绍

关系型和非关系型数据库


关系型数据库(表就是关系,或者说表与表之间存在关系)。


  • 所有的关系型数据库都需要通过sql语言来操作
  • 所有的关系型数据库在操作之前都需要设计表结构
  • 而且数据表还支持约束
  • 唯一的
  • 主键
  • 默认值
  • 非空

非关系型数据库


  • 非关系型数据库非常的灵活
  • 有的关系型数据库就是key-value对儿
  • 但MongDB是长得最像关系型数据库的非关系型数据库
  • 数据库 -》 数据库
  • 数据表 -》 集合(数组)
  • 表记录 -》文档对象

一个数据库中可以有多个数据库,一个数据库中可以有多个集合(数组),一个集合中可以有多个文档(表记录)


{
    qq:{
       user:[
           {},{},{}...
       ]
    }
}


  • 也就是说你可以任意的往里面存数据,没有结构性这么一说

安装


  • 下载
  • 安装

npm i mongoose


  • 配置环境变量
  • 最后输入mongod --version测试是否安装成功

启动和关闭数据库


启动:


# mongodb 默认使用执行mongod 命令所处盼复根目录下的/data/db作为自己的数据存储目录
# 所以在第一次执行该命令之前先自己手动新建一个 /data/db
mongod


如果想要修改默认的数据存储目录,可以:


mongod --dbpath = 数据存储目录路径


停止:


在开启服务的控制台,直接Ctrl+C;
或者直接关闭开启服务的控制台。


连接数据库


连接:


# 该命令默认连接本机的 MongoDB 服务
mongo


退出:


# 在连接状态输入 exit 退出连接
exit


基本命令


  • show dbs
  • 查看数据库列表(数据库中的所有数据库)
  • db
  • 查看当前连接的数据库
  • use 数据库名称
  • 切换到指定的数据库,(如果没有会新建)
  • show collections
  • 查看当前目录下的所有数据表
  • db.表名.find()
  • 查看表中的详细信息

总结与思考


  1. 数据模型:MongoDB 数据库采用文档存储方式,每个文档都是一个键值对的集合,其中键是字符串,值可以是多种类型的数据,例如字符串、数值、数组、嵌套文档等。这种数据模型比传统的关系型数据库更灵活,可以更好地适应非结构化的数据。
  2. 扩展性:MongoDB 支持水平扩展,可以通过添加更多的节点来扩展数据库的处理能力。在分布式系统中,这是一个非常重要的特性,可以保证系统的高可用性和高性能。
  3. 查询语言:MongoDB 支持类似 SQL 的查询语言,称为 MongoDB 查询语言(MQL),可以进行复杂的查询操作。同时,MongoDB 还支持 MapReduce 和聚合框架,这些功能可以用来进行更复杂的数据处理和分析。
  4. 高可用性:MongoDB 支持副本集(Replica Set)功能,可以保证数据的高可用性。副本集是多个 MongoDB 实例的集合,其中一个实例作为主节点,其他实例作为副本节点,主节点负责处理所有的写操作,副本节点则用来复制主节点的数据。当主节点故障时,副本节点可以自动选举出一个新的主节点,保证系统的高可用性。
  5. 缺点:MongoDB 的缺点之一是数据一致性问题,因为副本集需要时间来同步数据,所以在某些情况下可能会导致数据不一致。另外,MongoDB 也不适合用于需要多表联合查询的场景,因为 MongoDB 的数据模型不支持多表联合查询。

总的来说,MongoDB 是一款非常适合处理非结构化数据的 NoSQL 数据库,它具有高扩展性、高可用性和灵活的数据模型等优点,但也存在一些缺点需要注意。在选择数据库时,应该根据实际的业务需求和数据类型来进行选择。

相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
4月前
|
NoSQL atlas MongoDB
MongoDB
“【5月更文挑战第27天】”
47 2
|
9月前
|
存储 NoSQL MongoDB
关于MongoDB
关于MongoDB
124 0
|
存储 NoSQL 关系型数据库
什么时候选择MongoDB
什么时候选择MongoDB
83 2
|
存储
MongoDB-片键选择技巧
使用分片的目的是为了将数据存储到不同的服务器上, 所以在选择片键的时候,应该选择取值范围更广的字段作为片键,因为如果取值范围太小, 那么划分出来的数据段就太少, 那么分配到不同服务器的概率就越小, 例如:取值如果只有 true 或 false, 那么就只能划分出两个数据段, 那么也就最多只能保存到两台服务器上。
79 0
|
消息中间件 分布式计算 NoSQL
MongoDB适用场景
MongoDB适用场景
|
SQL JSON NoSQL
老去的MongoDB,未来在哪里?
老去的MongoDB,未来在哪里?
194 0
|
存储 缓存 NoSQL
MongoDB 使用介绍
MongoDB 是由 C++ 语言编写的,是一个基于分布式文件存储的非关系型开源数据库系统。其优势在于可以存放海量数据,具备强大的查询功能,是一个独立的面向集合文档形式的。
358 0
MongoDB 使用介绍
|
存储 分布式计算 NoSQL
MongoDB的主要特点
MongoDB 是一个面向文档存储的数据库,操作起来比较简单和容易。
144 0
|
存储 NoSQL 索引
什么场景应该用 MongoDB ?
月初在云栖社区上发起了一个 MongoDB 使用场景及运维管理问题交流探讨 的技术话题,有近5000人关注了该话题讨论,这里就 MongoDB 的使用场景做个简单的总结,谈谈什么场景该用 MongoDB? 很多人比较关心 MongoDB 的适用场景,也有用户在话题里分享了自己的业务场景,比如 案
|
NoSQL 数据库 索引
mongodb
mongodb installation mongodb-org mongodb-org-shell mongodb-org-tools mongodb-org-server config mongodb.
1032 0