关系型数据库和非关系型数据库的区别

1.常见的主流数据库

关系型数据库:

MySql 、达梦 、PostgreSQL 、Oracle 、Sql Server 、Sqlite
非关系型数据库:

Redis 、MongoDB 、HBase 、 Neo4J 、 CouchDB

2.介绍

关系型数据库最典型的数据结构是表,由二维表及其之间的联系所组成的一个数据组织,基于表格模型,适合结构化数据,支持高事务性。

非关系型数据库以键值对、文档或图结构存储数据,擅长横向扩展和处理大数据。

  1. 键值数据库:Redis、Memcached、Riak
  2. 列族数据库:Bigtable、HBase、Cassandra
  3. 文档数据库:MongoDB、CouchDB、MarkLogic
  4. 图形数据库:Neo4j、InfoGrid

3.区别

3.1 数据存储方式不同

主要差异在于数据存储的方式,关系型数据库是表格形式存储数据的,存储在鼠标的行和列中。数据表可以彼此关联写作存储,也容易提取数据。

非关系型数据不适合存储在数据表的行和列中,而是大块组合在一起。通常存储在数据集中,就像文档、键值对或者图结构。数据及其特性是选择数据存储和提取方式的首要影响因素。

3.2 扩展方式不同

SQL和NoSQL数据库最大的差别可能是在扩展方式上,要支持日益增长的需求当然要扩展,要支持更多并发量,SQL数据库是纵向扩展,也就是说提高处理能力,使用速度更快速的计算机,这样处理相同的数据集就更快了。因为数据存储在关系表中,操作的性能瓶颈可能涉及很多个表,这都需要通过提高计算机性能来客服。虽然SQL数据库有很大扩展空间,但最终肯定会达到纵向扩展的上限。

NoSQL数据库是横向扩展的。因为非关系型数据存储天然就是分布式的,NoSQL数据库的扩展可以通过给资源池添加更多普通的数据库服务器(节点)来分担负载。

3.3 对事务性的支持不同

如果数据操作需要高事务性或者复杂数据查询需要控制执行计划,那么传统的SQL数据库从性能和稳定性方面考虑是你的最佳选择。SQL数据库支持对事务原子性细粒度控制,并且易于回滚事务。

虽然NoSQL数据库也可以使用事务操作,但稳定性方面没法和关系型数据库比较,所以它们真正闪亮的价值是在操作的扩展性和大数据量处理方面。

相关推荐
秋也凉4 分钟前
redis的命令集合
数据库·redis·缓存
C++ 老炮儿的技术栈24 分钟前
Visual Studio 2022 MFC Dialog 添加Toolbar及Tips提示
服务器·c语言·数据库·c++·ide·算法·visual studio
王立志_LEO31 分钟前
数据库命名规范
mysql
秋难降38 分钟前
Python 知识点详解(二)
数据库·python·正则表达式
悟道|养家1 小时前
数据库性能优化指南:解决ORDER BY导致的查询性能问题( SQL Server )
数据库·性能优化
czhc11400756631 小时前
LINUX79 MYSQL
数据库·mysql
rocksun1 小时前
使用MCP Toolbox for Databases访问数据库
数据库·人工智能·mcp
程序员岳焱2 小时前
MySQL 基础 SQL 优化秘籍:4 大技巧让查询性能飙升!
后端·mysql·性能优化
星晨雪海3 小时前
MySQL安装报错解决
数据库·mysql
好奇的菜鸟9 小时前
Spring Boot 事务失效问题:同一个 Service 类中方法调用导致事务失效的原因及解决方案
数据库·spring boot·sql