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

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 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
相关文章
|
15天前
|
数据库 索引
深入探索数据库索引技术:回表与索引下推解析
【10月更文挑战第15天】在数据库查询优化的领域中,回表和索引下推是两个核心概念,它们对于提高查询性能至关重要。本文将详细解释这两个术语,并探讨它们在数据库操作中的作用和影响。
40 3
|
15天前
|
数据库 索引
深入理解数据库索引技术:回表与索引下推详解
【10月更文挑战第23天】 在数据库查询性能优化中,索引的使用是提升查询效率的关键。然而,并非所有的索引都能直接加速查询。本文将深入探讨两个重要的数据库索引技术:回表和索引下推,解释它们的概念、工作原理以及对性能的影响。
34 3
|
14天前
|
负载均衡 网络协议 数据库
选择适合自己的数据库多实例负载均衡技术
【10月更文挑战第23天】选择适合自己的数据库多实例负载均衡技术需要全面考虑多种因素。通过深入的分析和评估,结合自身的实际情况,能够做出明智的决策,为数据库系统的高效运行提供有力保障。
|
16天前
|
NoSQL Cloud Native atlas
探索云原生数据库:MongoDB Atlas 的实践与思考
【10月更文挑战第21天】本文探讨了MongoDB Atlas的核心特性、实践应用及对云原生数据库未来的思考。MongoDB Atlas作为MongoDB的云原生版本,提供全球分布式、完全托管、弹性伸缩和安全合规等优势,支持快速部署、数据全球化、自动化运维和灵活定价。文章还讨论了云原生数据库的未来趋势,如架构灵活性、智能化运维和混合云支持,并分享了实施MongoDB Atlas的最佳实践。
|
12天前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
26 3
|
17天前
|
NoSQL Cloud Native atlas
探索云原生数据库:MongoDB Atlas 的实践与思考
【10月更文挑战第20天】本文探讨了MongoDB Atlas的核心特性、实践应用及对未来云原生数据库的思考。MongoDB Atlas作为云原生数据库服务,具备全球分布、完全托管、弹性伸缩和安全合规等优势,支持快速部署、数据全球化、自动化运维和灵活定价。文章还讨论了实施MongoDB Atlas的最佳实践和职业心得,展望了云原生数据库的发展趋势。
|
14天前
|
缓存 负载均衡 监控
数据库多实例的负载均衡技术深入
【10月更文挑战第23天】数据库多实例负载均衡技术是确保数据库系统高效运行的重要手段。通过合理选择负载均衡策略、实时监控实例状态、不断优化调整,能够实现资源的最优分配和系统性能的提升。在实际应用中,需要根据具体情况灵活运用各种负载均衡技术,并结合其他相关技术,以满足不断变化的业务需求。
|
14天前
|
Java 数据库连接 数据库
优化之路:Java连接池技术助力数据库性能飞跃
在Java应用开发中,数据库操作常成为性能瓶颈。频繁的数据库连接建立和断开增加了系统开销,导致性能下降。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接,显著减少连接开销,提升系统性能。文章详细介绍了连接池的优势、选择标准、使用方法及优化策略,帮助开发者实现数据库性能的飞跃。
20 4
|
12天前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
15 1
|
14天前
|
SQL Java 数据库连接
打破瓶颈:利用Java连接池技术提升数据库访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,避免了频繁的连接建立和断开,显著提升了数据库访问效率。常见的连接池库包括HikariCP、C3P0和DBCP,它们提供了丰富的配置选项和强大的功能,帮助优化应用性能。
33 2