MySQL——存储引擎

存储引擎

InnoDB

是 MySQL 默认的存储引擎,只有在需要它不支持的特性时,才会考虑其他存储引擎

实现了 4 个标准的隔离级别,默认级别可重复度。在可重复度隔离级别下,通过 MVCC + 间隙锁防止幻读

主索引是聚簇索引

内部做了很多优化,包括磁盘读取数据时采用的可预测性读、能够加快读操作并且自动创建的自适应哈希索引、能够加快插入数据的插入缓冲区等

支持真正的在线热备份。其它存储引擎不支持在线热备份,要获取一致性视图需要停止对所有表的写入,而在读写混合场景中,停止写入可能也意味着停止读取。

MyISAM

设计简单,数据以紧密格式存储。对于只读数据,或者表比较小、可以容忍修复操作,则仍然可以使用它

提供了大量的特性,包括压缩表、空间数据索引等

不支持事务

不支持行级锁,只能对整张表加锁,读取时会对需要读到的所有表加共享锁,写入时则对表加排它锁。但在表有读取操作的同时,也可以往表中插入新的记录,这被称为并发插入(CONCURRENT INSERT)。

可以手工或者自动执行检查和修复操作,但是和事务恢复以及崩溃恢复不同,可能导致一些数据丢失,而且修复操作是非常慢的。

如果指定了 DELAY_KEY_WRITE 选项,在每次修改执行完成时,不会立即将修改的索引数据写入磁盘,而是会写到内存中的键缓冲区,只有在清理键缓冲区或者关闭表的时候才会将对应的索引块写入磁盘。这种方式可以极大的提升写入性能,但是在数据库或者主机崩溃时会造成索引损坏,需要执行修复操作。

InnoDB 对比 MyISAM

  • Innodb支持行级锁,事务,外键,数据库异常后的安全恢复,支持MVCC,只有不需要支持它的特性时,才会考虑其他的存储引擎
  • 索引实现不同,虽然都是B+树,InnoDB支持"聚簇索引",MyISAM不支持。聚簇索引可以大大提升性能,因为它将数据按照主键排序物理存储,使得相邻的数据在物理存储上也是相邻的,减少了数据的IO读取
  • CRUD操作:
    MyISAM:如果执行大量的SELECT,MyISAM是更好的选择。
    InnoDB:如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表。DELETE 从性能上InnoDB更优,但DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除,在innodb上如果要清空保存有大量数据的表,最好使用truncate table这个命令。
  • 崩溃恢复: MyISAM 崩溃后发生损坏的概率比 InnoDB 高很多,而且恢复的速度也更慢。
  • 其它特性: MyISAM 支持压缩表和空间数据索引,InnoDB 支持外键,支持在线热备份

Memory

是一种基于内存的存储引擎

相比于其它存储引擎,Memory 存储引擎可以快速地创建或删除表,因为它的表是纯内存的,数据可以在不同的客户端之间共享,且不需要频繁地读写硬盘,所以在一些特定的场景下,使用 Memory 存储引擎可以获得较高的性能表现。例如,存放一些暂时数据,类似于缓存操作,或者作为临时表等。

不过,由于 Memory 存储引擎宕机后数据将会全部丢失,所以它不适合存放重要的数据。此外,Memory 存储引擎还存在一些限制,例如只支持表锁,不支持事务、不支持 BLOB 和 TEXT 类型、不支持自动增长列等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/720197.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Docker 日志存储大小限制,默认会充爆磁盘

背景 在容器化部署的时候,因为没有指定日志的最大存储时间,导致磁盘被充爆。查看日志 一般使用docker logs -f --tail 行数 容器名称 来查看容器的运行日志,但是在容器被初始化的时候,需要指定日志的最大存储时间,因为…

React学习笔记

1、React初步认识 React构建Web和原生交互界面的库,相较于其它前端框架的优势,具有丰富的生态跨平台支持。 1.1、React的开发依赖 开发React必须依赖三个库: react:包含react所必须的核心代码;react-dom:react渲染在不同平台所需要的核心代码 ;babel:将jsx转换成Rea…

白云山板蓝根,一年四季都得备着

上班半年,每天都感觉在行尸走肉,长时间地坐在电脑前真的不行!身体越来越差,面相也越来越糟糕,不仅有黑眼圈,痘痘也冒出来了不少,堪比整容,朋友们都纷纷调侃我,说我上半年…

限流、流量削峰?

学MQ的时候,经常会有人拿秒杀这个场景去介绍流量削峰。这很好理解,将请求放到一个中转站去暂存,虽然生产者生产很快,但消费者可以慢慢去中转站获取。 关于限流,之前一直以为限流的思想类似MQ,不过是内存中…

网络安全: Kali Linux 使用 docker-compose 部署 openvas

目录 一、实验 1.环境 2.Kali Linux 安装docker与docker-compose 3.Kali Linux 使用docker-compose方式部署 openvas 4. KaliLinux 使用openvas 二、问题 1. 信息安全漏洞库 2.信息安全漏洞共享平台 3.Windows 更新指南与查询 4.CVE 查询 5.docker-compose 如何修改o…

前后端分离项目Docker部署指南(上)

目录 前言 一.搭建局域网 1.搭建net-ry局域网,用于部署若依项目 2.注意点 二.安装redis 创建目录 将容器进行挂载 ​编辑 测试是否安装成功 ​编辑 三. 安装MySQL 创建文件夹 上传配置文件并且修改 .启动MySQL容器服务 充许远程连接 四.部署后端 使用…

LLVM clang_tokenize 的示例

1, 环境搭建 如同上篇 git clong llvm-project git checkout llmvorg-3.4.0 # or llvmorg-18.1.rc /bin/bash ./confiure --prefix....... # or cmake Debug make -j32 make -j install 2, 示例代码 Makefile:如同上篇 LLVM_CON…

机器学习中的 K-均值聚类算法及其优缺点。

K-均值聚类算法是一种常用的无监督学习算法,用于将数据集划分为K个不重叠的类别。该算法基于数据点之间的距离度量,通过不断迭代的方式将数据点分配给最近的聚类中心,并更新聚类中心的位置,直到达到收敛条件或最大迭代次数。 K-均…

关于“定时器中断干扰串口中断,导致串口中断数据接收不完整”的问题

问题描述 最近在做的项目,基于modbusRTU,上位机通过wifi模块给单片机发数据。 上位机每隔100ms,周期性发送0x03和0x10。 因为要及时的处理上位机发来的指令,我是在一个10ms的定时器中断中进行modbus数据处理。这就导致一个问题&…

MySQL JSON 路径表达式语法

MySQL JSON 路径表达式语法 语法 MySQL中支持的许多JSON函数,需要路径表达式以便识别JSON文档中的特定元素。路径由路径的作用域和一个或多个路径段组成。在MySQL JSON函数中使用的路径中,作用域始终是正在搜索或以其他方式操作的文档,由前…

NOIP 2010普及组初赛试题及解析

NOIP 2010普及组初赛试题及解析 一. 单项选择题 (共20题,每题1.5分,共计30分。每题有且仅有一个正确答案.)。二. 问题求解(共2题,每题5分,共计10分)三. 阅读程序写结果(共…

AcWing 803. 区间合并

Problem: AcWing 803. 区间合并 文章目录 思路解题方法复杂度Code 思路 这是一个区间合并的问题。我们需要找出尽可能多的不相交的区间。首先,我们将所有的区间按照左端点从小到大进行排序。然后,我们遍历所有的区间,如果当前区间的左端点大于…

什么是Redis?|介绍与使用及特点浅记

Redis简介 Redis(Remote Dictionary Server)是一种基于内存、支持持久化的键值对存储系统,具有丰富的数据结构和高性能的特性。它不仅可以作为数据库,还可以作为缓存和消息中间件使用。Redis是单线程模型,但利用IO多路…

【丹尼早晚安】打卡第六天,英语学习笔记

成分颜色主语(subject)橙色谓语(predicate)蓝色宾语(object)红色定语(attribute)紫色状语(adverbial)棕色补语(complement)粉色 早上…

基于YOLOv8深度学习的农作物幼苗与杂草检测系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标检测

《博主简介》 小伙伴们好,我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~ 👍感谢小伙伴们点赞、关注! 《------往期经典推…

排序算法(1):直接插入排序

原文链接(原文也是我写的哈,强烈推荐去原文链接看):直接插入排序 - Fucking Code 直接插入排序(Straight Insertion Sort)是一种最简单的排序方法,其基本操作是将一条记录插入到已排好的有序表中…

kafka启动命令、查看topic命令、查看消息内容命令

kafka启动命令 cd /opt/kafka/kafka_2.12-3.5.1/bin ./kafka-server-start.sh ../config/server.properties Windows环境下用kafka Tool 连不上虚拟机的broker报了unable to connect broker 0, 但是zookeeper可以连接上 server.properties的listeners改为listene…

006-CSS-常见问题汇总

常见问题汇总 1、伪元素与伪类2、偏门但好用的样式3、文字溢出三个点展示4、空白折叠问题5、文字的垂直居中6、 Vue项目中 在父组件中修改子组件样式7、BFC 概念7.1、兄弟元素外边距合并7.2、父子元素外边距塌陷 8、box-sizing8.1、box-sizing: border-box8.2、box-sizing: con…

Vue.js 深度解析:nextTick 原理与应用

🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…

英特尔/ARM/国产化EMS储能控制器解决方案

新型储能是建设新型电⼒系统、推动能源绿⾊低碳转型的重要装备基础和关键⽀撑技术,是实现碳达峰、碳中和⽬标的重要⽀撑。说到储能,大众首先想到的就是电池,其好坏关系到能量转换效率、系统寿命和安全等重要方面,但储能要想作为一…