当前位置: 首页 > news >正文

【数据库基础】Mysql与Redis的区别

看到一篇不错的关于“Mysql与Redis的区别”的文章,转过来记录下~

文章目录

    • 一、数据库类型
    • 二、运行机制
    • 三、什么是缓存数据库呢?
    • 四、优缺点比较
    • 五、区别总结
    • 六、数据可以全部直接用Redis储存吗?
    • 参考资料

一、数据库类型

  • Redis:NOSQL,非关系型数据库,也叫缓存数据库。将数据存储在缓存中,这虽然提高了运行效率,但是保存时间却很短。

  • MySQL:关系型数据库,主要是用于存放持久化数据,将数据存储在硬盘中,但这样会造成读取速度慢。

二、运行机制

  • Redis:基于单线程,效率比较高,因为它是基于内存操作,所以CPU不是性能瓶颈,机器内存及宽带才是Redis的瓶颈。

  • MySQL:作为储存的的关系型数据库,弱点就是在每次请求访问数据库时,都存着I/O操作,如果频繁访问数据库会产生如下一些问题:
    – a.会在反复链接数据库上花费大量时间,从而导致运行效率过慢
    – b.反复的访问数据库也会导致数据库的负载过高,此时就引出缓存的概念

三、什么是缓存数据库呢?

缓存就是数据交换的的缓冲区,当浏览器执行请求时,首先会对缓存中进行查找,如果存在就获取;否则就会访问数据库。

缓存的好处:最最最直观好处就是读取速度快。

Redis的数据库就是一款缓存数据库,用于存储使用频繁的数据,这样减少访问数据库的次数,提高运行效率。

四、优缺点比较

在这里插入图片描述
在这里插入图片描述

五、区别总结

1. 数据库类型的区别

  • MySQL是关系型数据库
  • Redis是非关系型数据库,缓存数据库。

2. 作用上的区别

  • MySQL用于持久化存储数据到硬盘,功能强大,但是速度缓慢。
  • Redis用于存储使用较为频繁的数据到缓存中,读取速度快。

3.数据存储的位置区别

  • Mysql:数据存放在磁盘中,
  • Redis:数据存放在内存中。

4.存放的数据类型区别

  • Mysql:数值、日期、具体时间、字符串
  • Redis:String、Hash、List、Set、Zset

5.需求上的区别

mysql和redis因为需求的不同,一般都是配合使用。

  • 需要高性能的地方使用Redis
  • 不需要高性能的地方使用MySQL

存储数据在MySQL和Redis之间做同步。

六、数据可以全部直接用Redis储存吗?

我们将逐个分析:

1.MySQL存储在磁盘里,Redis存储在内存里。

Redis既可以用来做持久存储,也可以做缓存,而目前大多数公司的存储都是MySQL + Redis,MySQL作为主存储,Redis作为辅助存储被用作缓存,加快访问读取的速度,提高性能。

2.Redis存储在内存中,如果存储在内存中,存储容量肯定要比磁盘少很多,那么要存储大量数据,只能花更多的钱去购买内存,造成在一些不需要高性能的地方是相对比较浪费的,所以目前基本都是MySQL(主) + Redis(辅),在需要性能的地方使用Redis,在不需要高性能的地方使用MySQL。

3.MySQL支持sql查询,可以实现一些关联的查询以及统计。

4.Redis对内存要求比较高,在有限的条件下不能把所有数据都放在Redis。

5.MySQL偏向于存数据,Redis偏向于快速取数据。
但是Redis查询复杂的表关系时,不如MySQL,所以可以把热门的数据放Redis,MySQL存基本数据。

参考资料

  • Mysql与Redis的区别
http://www.lryc.cn/news/276494.html

相关文章:

  • JVM工作原理与实战(六):类的生命周期-连接阶段
  • 【OCR】 - Tesseract OCR在Windows系统中安装
  • YOLOv8改进 | 损失函数篇 | SlideLoss、FocalLoss分类损失函数助力细节涨点(全网最全)
  • 计算机网络试题——填空题(附答案)
  • 第二证券:股票私募仓位指数创近八周新高
  • 35-javascript基础,引入方式;变量命名规范
  • 笔试案例2
  • 【嵌入式-网络编程】vmware中使用UDP广播失败问题
  • 2020年认证杯SPSSPRO杯数学建模D题(第二阶段)让电脑桌面飞起来全过程文档及程序
  • vue3 修饰符大全(近万字长文)
  • HarmonyOS@State装饰器:组件内状态
  • 如何让GPT支持中文
  • 使用开源通义千问模型(Qwen)搭建自己的大模型服务
  • Java工程师面试题解析与深度探讨
  • Linux下安装JET2
  • 【PostgreSQL】表管理-表继承
  • Dijkstra算法——邻接矩阵实现+路径记录
  • Vim基础操作
  • Mac上安装 Node.js 的版本管理工具 n,以及 n 使用,的使用
  • Node.js和npm
  • leetcode每日一题43
  • 每天刷两道题——第十天
  • C语言入门教程,C语言学习教程(第一部分:编程基础 )一
  • uniapp微信小程序投票系统实战 (SpringBoot2+vue3.2+element plus ) -用户信息修改实现
  • C语言PDF编程书籍下载
  • VScode/Xshell连接学校服务器
  • 46 WAF绕过-信息收集之反爬虫延时代理池技术
  • [Markdown] Markdown常用快捷键分类汇总
  • uniapp自定义封装只有时分秒的组件,时分秒范围选择
  • SpringBoot 中 @Transactional 注解的使用