非关系型数据库-MongoDB技术(二)

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

今天先分享下关于nosql下吧!!!!

* 什么是NoSQL数据库

* NoSQL数据库有哪些特征和种类

* NoSQL数据库与RDB有什么区别,该如何去选择

一、什么是NoSQL数据库

1⃣️、NoSQL是非关系型数据库的统称,而且NoSQL中数据之间的关联较少,因此更容易分散存储。随着Web2.0网站的应用越来越广泛,网站所收集的数据量大到我们难以想象,一般关系型数据库越来越难适应这一类的应用场景,而NoSQL数据库在存储这些大量的数据时,是并没有什么绝对的固定的格式的,数据是独立存在的。

2⃣️、MongoDB它除了NoSQL数据库的优势之外,还扩展了关系型数据库的一些实用功能。

a、MongoDB具有直观且完善的数据处理指令,对新手来说很容易上手

b、MongoDB提供了驱动(Driver)和丰富的API。

c、MongoDB还提供了完善的管理模式和配置方式,对于DB人员来说很方便

二、NoSQL数据库有哪些特征和种类

1⃣️、可扩展

NoSQL去掉了关系型数据库的关联特性,因此数据之间没有任何的关联,更容易扩展。

2⃣️、Base理论特征

基本可用性,可伸缩性,最终一致性。但相比关系型数据库的ACID特征,NoSQL数据库仅仅保证具有Base特征。

3⃣️、大数据量,高性能

因为数据的关联性较小且数据结构单纯,所以更容易实现并发处理,所以NoSQL更有很高的读/写的性能。

4⃣️、很灵活的数据模型

不需要事先定义数据字段,可以随时去自定义的数据格式,这样很容易的去新增一个字段。这样就很容易的保存格式多变的非结构化数据或者半结构化数据。

半结构化数据:是一种介于结构化数据和非结构化数据之间的数据,比如,json,xml,html文件。

5⃣️、高可用

可以通过副本集实现故障转移,保证高可用。

种类:

1⃣️、文档型数据库:即将单个实体的所有数据都存在一个文档中, 而文档是存在集合中的。例如:MongoDB技术。

2⃣️、key-value的数据库:用数据库中的键来查找特定数据的value。

优点:在存储时不采用任何的模式,因此极易添加数据。

缺点:只针对“值”来查找的性能就会比较差,如果一对一来查找的话性能就较高。适用于大量数据的高访问负载场景,比如日志系统,例如:Redis。

3⃣️、列存储数据库:以”列“为单位的来存储数据,更适合于批量数据来处理和实时数据查询,和压缩。缺点:不适用于实时的删除或者更新的操作。

4⃣️、图存储数据库:采用图形理论来存储实体之间的关系信息。如社交关系网络。

三、NoSQL数据库与RDB该怎么去选择

NoSQL数据库并不能完全取代于关系型数据库,NoSQL数据库主要被用来处理大量且多元数据的存储以及计算的问题。

1⃣️、数据模型的关联性要求

a、需要多表关联,采用RDB。

b、对象实体关联少,更适合NoSQL。其中MongoDB可支持复杂度相对高的数据结构。可以文档嵌套文档的方式存储,从而减少shu句之间的关联操作。

2⃣️、数据库的性能来看

如果数据量比较多而且速度要求很高的话可以使用NoSQL数据库。

3⃣️、数据的一致性来看

NoSQL数据库很难同时满足强一致性和高并发性。如果程序对性能很高的话,NoSQL数据库只能做到最终一致性。

4⃣️、数据的可能性

NoSQL数据库提供了强大的数据可用性。

所以说:一个项目中并不是只用一种数据库,RDB特性的数据可以放入到RDB中去管理,比如交易系统。其他数据可以放入到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
相关文章
|
2天前
|
NoSQL 关系型数据库 MongoDB
非关系型数据库-MongoDB技术(一)
非关系型数据库-MongoDB技术(一)
|
14天前
|
存储 负载均衡 数据库
探索后端技术:从服务器架构到数据库优化的实践之旅
在当今数字化时代,后端技术作为支撑网站和应用运行的核心,扮演着至关重要的角色。本文将带领读者深入后端技术的两大关键领域——服务器架构和数据库优化,通过实践案例揭示其背后的原理与技巧。无论是对于初学者还是经验丰富的开发者,这篇文章都将提供宝贵的见解和实用的知识,帮助读者在后端开发的道路上更进一步。
|
JSON NoSQL Java
mongoDB导出数据库所有集合内容到json文件
网上搜了一圈,官方并有提供批量导出所有集合到json文件的方法。有不少脚本可以实现,但是我还是习惯用java,如下 package starcLL.
2202 0
|
1月前
|
运维 监控 NoSQL
【MongoDB 复制集秘籍】Secondary 同步慢怎么办?深度解析与实战指南,让你的数据库飞速同步!
【8月更文挑战第24天】本文通过一个具体案例探讨了MongoDB复制集中Secondary成员同步缓慢的问题。现象表现为数据延迟增加,影响业务运行。经分析,可能的原因包括硬件资源不足、网络状况不佳、复制日志错误等。解决策略涵盖优化硬件(如增加内存、升级CPU)、调整网络配置以减少延迟以及优化MongoDB配置(例如调整`oplogSize`、启用压缩)。通过这些方法可有效提升同步效率,保证系统的稳定性和性能。
43 4
|
1月前
|
监控 NoSQL MongoDB
MongoDB数据库的索引管理技巧
【8月更文挑战第20天】MongoDB数据库的索引管理技巧
45 1
|
1月前
|
监控 NoSQL MongoDB
mongodb数据库 使用技巧
【8月更文挑战第20天】mongodb数据库 使用技巧
35 1
|
1月前
|
JSON NoSQL Ubuntu
在Ubuntu 14.04上如何备份、恢复和迁移MongoDB数据库
在Ubuntu 14.04上如何备份、恢复和迁移MongoDB数据库
61 1
|
1月前
|
NoSQL 大数据 MongoDB
云中对决:Amazon DocumentDB 与 MongoDB的终极较量,谁将主宰云端数据库的未来?
【8月更文挑战第8天】在云计算与大数据时代,文档数据库因灵活高效备受开发者青睐。本文作为指南,全面对比Amazon DocumentDB与MongoDB。DocumentDB兼容MongoDB,便于迁移;在AWS环境下,它提供卓越的性能与自动伸缩能力。MongoDB则侧重于自定义部署与成本控制。DocumentDB作为托管服务简化管理但成本较高,而MongoDB需自行处理安全性与备份。根据需求与预算,开发者可作出最佳选择。
43 3
|
26天前
|
C# 开发者 Windows
全面指南:WPF无障碍设计从入门到精通——让每一个用户都能无障碍地享受你的应用,从自动化属性到焦点导航的最佳实践
【8月更文挑战第31天】为了确保Windows Presentation Foundation (WPF) 应用程序对所有用户都具备无障碍性,开发者需关注无障碍设计原则。这不仅是法律要求,更是社会责任,旨在让技术更人性化,惠及包括视障、听障及行动受限等用户群体。
47 0
|
26天前
|
Java 前端开发 Spring
技术融合新潮流!Vaadin携手Spring Boot、React、Angular,引领Web开发变革,你准备好了吗?
【8月更文挑战第31天】本文探讨了Vaadin与Spring Boot、React及Angular等主流技术栈的最佳融合实践。Vaadin作为现代Java Web框架,与其他技术栈结合能更好地满足复杂应用需求。文中通过示例代码展示了如何在Spring Boot项目中集成Vaadin,以及如何在Vaadin项目中使用React和Angular组件,充分发挥各技术栈的优势,提升开发效率和用户体验。开发者可根据具体需求选择合适的技术组合。
32 0