非关型数据库之MongoDB

本文涉及的产品
云数据库 MongoDB,通用型 2核4GB
简介: 非关型数据库之MongoDB

1 MongoDB简介

1.1 初识MongoDB

       MongoDB来源自英文单词"Humongous”,译为“庞大的”从中可见MongoDB的存储容量不可谓小,MongoDB是一个开源的文档数据库,使用C++语言编写。其中主要的功能特性为:面向集合存储,易于存储数据类型的数据,模式自由,支持动态查询,支持完全索引,支持复制和故障恢复,使用高效的二进制数据存储,文件存储格式为BSON(JSON的一种二进制形式的存储格式)。


1.2 MongoDB与传统的关系型数据库的区别


存储结构对应关系

存储结构 关型数据库 MongoDB

数据库 database database

数据表/集合 table collection

行/文档 row document

列/字段(属性) column field

主键 primary key primary key

表连接 table join 不支持连接

嵌套关系 不支持嵌套 字段(属性)可以嵌套其他文档


结构上区别

关型数据库 MongoDB

存储结构(从大到小) 数据库、表、行 数据库、集合、文档、键值对

结构类型 表结构需要预定义 文档的结构是可变的

事务特性 ACID BASE

ACID:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)


BASE:基本可用(Basically Available)、软状态(Soft-state)、最终一致性(Eventually Consistent)

1.3 MongoDB存储结构

💥键值对

       MongoDB存储结构的基本结构单位是键值对,键的格式一般是字符串,值的格式可以是字符串、数值、文档等,当值的格式是文档时就是我们所说的嵌套键值对,其他都是基本键值对。键(Key)起到唯一索引的作用,区分大小写;值(Value)是键所对应的数据,通过键来获取其内容。


💥文档


       文档是由多个键值对的有序集合,使用{ }符号进行包裹。键值对的顺序确定一个文档,也就是说就算两个文档的键值对内容完全一样,但是键值对顺序不一样,依然是两个文档。一个文档中的键重复时,后面的值覆盖前面的。文档必须有一个“_id”的键来唯一标识该文档,自己创建或者默认生成。MongoDB中文档之间的关系包括嵌入和引用两种:


引用就是在一个文档里引用另一个文档里的值:


{
id: "joe",
name: "joe Bookreader"
}
{
patron_id: "joe",
street: "123 Fake Street",
city: "Faketon",
state: "MA",
zip: "123456"
}

嵌入就是常说的嵌套键值对:


{
id: "joe",
name: "joe Bookreader"
address: {
         patron_id: "joe",
         street: "123 Fake Street",
         city: "Faketon",
         state: "MA",
         zip: "123456"
         }
}

💥集合


       集合是由多个文档构成的对象,许多文档储存在一个集合中。


💥数据库


       数据库是由许多的集合组成。


1.4 BSON支持的数据类型


类型 描述

NULL 空值或不存在的字段 {"x":null}

Boolean true和false {"x":true}

String BSON编码是utf-8 {"x":"文档数据库"}

Number 数值(默认64位浮点数) {"x":3.14}

Array 数组 {"x":["a","b","c"]}

Object 内嵌文档 {"x":{"y":4.23}}

ObjectId 文档的唯一标识 {"x":ObjectId()}

Binary Data 二进制数据

JavaScript 代码

Date 日期 {"x":new Date()}

Timstamp 时间戳

Regular Expression 正则表达式

2  MongoDB Shell操作

参考博客:

cMongoDB Shell操作_扎哇太枣糕的博客-CSDN博客


3 MongoDB集群操作

参考博客:

MongoDB副本集、分片集的伪分布式部署(保姆级教程)_扎哇太枣糕的博客-CSDN博客


相关实践学习
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
相关文章
|
2天前
|
NoSQL MongoDB 数据库
MongoDB数据恢复—MongoDB数据库文件被破坏的数据恢复案例
服务器数据恢复环境: 一台Windows Server操作系统服务器,服务器上部署MongoDB数据库。 MongoDB数据库故障&检测: 工作人员在未关闭MongoDB数据库服务的情况下,将数据库文件拷贝到其他分区。拷贝完成后将原MongoDB数据库所在分区进行了格式化操作,然后将数据库文件拷回原分区,重新启动MongoDB服务,服务无法启动。
|
5天前
|
NoSQL MongoDB Redis
Python与NoSQL数据库(MongoDB、Redis等)面试问答
【4月更文挑战第16天】本文探讨了Python与NoSQL数据库(如MongoDB、Redis)在面试中的常见问题,包括连接与操作数据库、错误处理、高级特性和缓存策略。重点介绍了使用`pymongo`和`redis`库进行CRUD操作、异常捕获以及数据一致性管理。通过理解这些问题、易错点及避免策略,并结合代码示例,开发者能在面试中展现其技术实力和实践经验。
108 8
Python与NoSQL数据库(MongoDB、Redis等)面试问答
|
1月前
|
NoSQL 网络协议 MongoDB
Windows公网远程连接MongoDB数据库【无公网IP】
Windows公网远程连接MongoDB数据库【无公网IP】
|
1月前
|
存储 NoSQL 关系型数据库
一篇文章带你搞懂非关系型数据库MongoDB
一篇文章带你搞懂非关系型数据库MongoDB
57 0
|
1月前
|
人工智能 NoSQL MongoDB
|
2月前
|
SQL NoSQL Java
文档型数据库MongoDB
文档型数据库MongoDB
|
2月前
|
JSON NoSQL MongoDB
MongoDB详解(五)——MongoDB数据库简单使用
MongoDB详解(五)——MongoDB数据库简单使用
106 1
|
5天前
|
关系型数据库 MySQL 分布式数据库
《MySQL 简易速速上手小册》第6章:MySQL 复制和分布式数据库(2024 最新版)
《MySQL 简易速速上手小册》第6章:MySQL 复制和分布式数据库(2024 最新版)
35 2
|
21天前
|
SQL 数据可视化 关系型数据库
轻松入门MySQL:深入探究MySQL的ER模型,数据库设计的利器与挑战(22)
轻松入门MySQL:深入探究MySQL的ER模型,数据库设计的利器与挑战(22)
105 0
|
21天前
|
存储 关系型数据库 MySQL
轻松入门MySQL:数据库设计之范式规范,优化企业管理系统效率(21)
轻松入门MySQL:数据库设计之范式规范,优化企业管理系统效率(21)