03-关系和非关系型数据库对比

关系和非关系型数据库对比

关系型数据库(RDBMS):MySQL、Oracl、DB2、SQLServer
非关系型数据库(NoSql):Redis、Mongo DB、MemCached

插入数据结构的区别

传统关系型数据库是结构化数据,向表中插入数据时都需要严格的约束信息(如字段名,字段数据类型,字段约束等信息)

非关系型数据库对插入的数据格式没有严格约束,可以是键值型,文档型(如MongoDB),图格式(如Neo4j),列类型(如HBase)

多表关联的区别

传统数据库的表与表之间往往存在关联(如外键)

  • 传统数据库在维护用户商品的关系会新建一个订单表,存储用户和商品的对应关系
  • 在业务逻辑代码中存储数据时需要将商品的信息存储到用户的订单属性中,但是这样做会导致数据冗余
json 复制代码
{
  id: 1,
  name: "张三",
  orders: [
    {
       id: 1,
       item: {
	 		id: 10, title: "荣耀6", price: 4999
       }
    },
    {
       id: 2,
       item: {
	 		id: 20, title: "小米11", price: 3999
       }
    }
  ]
}

非关系型数据库的表与表之间不存在关联关系,维护关系只能靠代码中的业务逻辑或数据之间的耦合

查询方式的区别

传统关系型数据库会基于Sql语句做查询(语法有统一标准),非关系数据库查询语法各种各样差异极大

事务的区别

传统关系型数据库能满足事务ACID的原则(原子性、一致性、独立性及持久性)

非关系型数据库往往不支持事务,或者不能严格保证ACID的特性,只能实现基本的一致性

存储方式磁盘和内存的区别

  • 关系型数据库基于磁盘进行存储, 会有大量的磁盘IO所以对性能有一定影响
  • 非关系型数据库的基于内存来存储, 内存的读写速度会非常快所以性能较高

扩展性水平扩展和垂直扩展的区别

  • 垂直扩展: 关系型数据库集群模式一般是主从, 主从数据一致可以起到数据备份的作用
  • 水平扩展: 非关系型数据库可以将数据拆分存储在不同机器上,可以保存海量数据解决内存大小有限的问题
  • 关系型数据库因为表之间存在关联关系, 如果做水平扩展会给数据查询带来很多麻烦
相关推荐
Chengbei112 分钟前
若依全漏洞复现:从 SQL 注入到 RCE 一站式实战 复现、利用与防御
数据库·sql·安全·web安全·网络安全·系统安全·安全架构
小江的记录本12 分钟前
【事务】Spring Framework核心——事务管理:ACID特性、隔离级别、传播行为、@Transactional底层原理、失效场景
java·数据库·分布式·后端·sql·spring·面试
数据皮皮侠43 分钟前
中国城市间地理距离矩阵(2024)
大数据·数据库·人工智能·算法·制造
lars_lhuan1 小时前
从键值数据库到Redis
数据库·redis·缓存
倔强的石头1061 小时前
KaiwuDB社区版 3.1.0 在 Ubuntu 22.04 部署实战:TLS 配置、踩坑复盘与轻量压测
数据库·ubuntu·kwdb
liwenzhuola1 小时前
解决 Ubuntu 上 Qt Creator 项目编译失败的问题
数据库·qt·ubuntu
万邦科技Lafite2 小时前
利用淘宝商品详情接口获取商品价格,监控商品价格浮动
数据库·api·开放api接口·淘宝开放接口
程序员阿伦3 小时前
璋㈤鏈虹殑Java澶у巶闈㈣瘯璁帮細浠嶴pring Boot鍒癒ubernetes锛�3杞湡棰樺叏瑙f瀽锛�
spring boot·redis·kubernetes·aigc·java闈㈣瘯·寰湇鍔�·鐢靛晢绉掓潃
深藏功yu名3 小时前
Day24:向量数据库 Chroma_FAISS 入门
数据库·人工智能·python·ai·agent·faiss·chroma
知识分享小能手3 小时前
MongoDB入门学习教程,从入门到精通,MongoDB创建、更新和删除文档(3)
数据库·学习·mongodb