mysql---存储引擎

目录

mysql---存储引擎

功能:

mysql的存储引擎分类

MYISAM和INNODB做个对比

MYISAM

在磁盘上有三个文件:

MYISAM的特点:

支持的存储格式:

INNODB

innodb的特点

使用场景:

三个文件:

行锁

表锁

排他锁 

死锁/悲观锁

乐观锁

如何尽可能地避免死锁:


mysql---存储引擎

存储引擎:mysql当中数据用各种不同的技术存储在文件中,每一种技术都使用不同的存储机制,索引技巧,锁定水平,以及最终提供的不同功能和能力,这些就是我么说的存储引擎

功能:

1、mysql将数据存储在文件系统中的一种方式和格式
2、存储引擎负责执行实际的数据I/O操作
3、存储引擎介于数据和文件系统之间,数据会先保存到引擎,再按照存储殷勤的格式保存到文件系统

mysql的存储引擎分类

1、INNODB-5.5之前mysql的默认存储引擎,事务性速记引擎。支持CAID事务。支持行锁,表锁,写入和查询性能比较好
2、MYISAM:.5.5之前的默认存储引擎。插入数据的性能较高,查询速度也很优秀。但是不支持事务。
3、memory: 所有数据都保存在内存的存储引擎。插入数据,更新,查询数据,速度比较快。但是占用内存空间比较大。会占用和数据量成正比的内存空间。mysql一旦重启,内容就会丢失。
4、csv:是由逗号分割的存储引擎。他会在数据库子目录里为每一个数据表创建一个csv的文件。就是一个普通的数据文件,每个数据占用一个文本行,csv不支持索引。
5、archive:非常适合存储大量的,独立的,历史数据的引擎。插入的速度很快。查询的效率比较低。
6、blackhole:黑洞引擎,写入的任何数据都会消失。


MYISAM和INNODB做个对比

MYISAM

MYISAM:不支持事务,也不支持外键,只支持全文索引,数据文件和索引是分开的
访问速度快
使用场景:查询和插入数据为主的应用

在磁盘上有三个文件:

编译安装:/usr/local/mysql/data/数据库名/下

文件和表名相同,但扩展名不同:
.frm:存储表结构
.MYD:存储数据文件
.MYI:存储索引文件

vim /etc/my.cnf
--INNODB改为MYISAM
systemctl restart mysqld 

MYISAM的特点:

1、表级锁定,更新数据时,整个都将锁定。
2、数据库在读写过程中相互阻塞。

支持的存储格式:

1、静态表,固定长度表,静态表式mvisam的默认存储格式。静态表中字段都是非可变字段。每个记录都是固定长度。存储快,方便缓存,有了故障容易恢复,缺点是占用空间比较多。
2、动态表,动态表可以包含可变字段,记录的长度是不固定的。优点是占用空间少。频繁更新数据,删除记录,会产生碎片。定期清理。myisamchk -r。出现故障恢复比较困难。
3、压缩表,myisamchk工具创建,占用空间非常小,每条记录都是单独压缩。

INNODB

支持事务,支持4个事务的隔离级别。5.5之后mysql默认存储引擎。
读写阻塞和隔离级别相关。
支持高校的缓存索引以及缓存数据。
表于主键以族方式存储BTREE。

支持外键约束,5.5之后innodb也可以支持全文索引
硬件资源的要求比较高。
行锁定
也可以支持表锁定(全表扫描)

1、使用like模糊查询,会进行全表扫描,锁定整个表
2、对没有创建索引的字段进行查询,也会纪念性全表扫描。锁定整个表。
3、使用索引,进行增删改,则是行级锁定。


innodb的特点

1、不保存表的行数,统计表的行数,扫描一遍整个表来计算多少行。
2、自增长字段,innodb中必须包含又该字段的索引
3、delete清空表,一行一行删,速度比较truncate快

使用场景:

1、业务需要事务支持。
2、论坛、微博、对数据一致性比较高的场景
3、访问量和并发量比较高的场景,innodb支持缓存,就按少后台服务器的压力。

三个文件:

编译安装:/usr/local/mysql/data/数据库名/下

表名.frm 表结构文件
表名.ibd 即使数据文件,又是索引文件
db.opt 表的属性文件

innodb行锁和索引的关系 以及表锁 排他锁 死锁。

行锁

如果name字段是一个普通索引,会锁住索引行,对应的主键一并锁住,实际上就是行锁。
如果使用的字段的是主键,innodb对主键使用聚簇索引,锁定整行的记录,锁行。

对于数据库中的某一行数据进行的锁定,以确保在对该行数据进行读取或修改时,不会发生数据冲突或数据丢失等问题。可以实现更高的并发性。

表锁

当一个事务对非索引列操作,因为要全表扫描,整张表都被锁定,另一个事务只能查。

在数据库操作中,对于一个表进行的锁定,以确保在对该表进行修改或读取时,不会发生数据冲突或数据丢失等问题。


排他锁 /悲观锁

只能设置排他锁的事务操作,其他的事务操作无法执行,只能等其commit之后才可。只能加一个

排他锁则只允许一个用户对该表进行修改或读取操作,其他用户无法同时进行读写操作。

将访问数据的操作加上锁,例如在MySQL中,可以使用SELECT ... FOR UPDATE语句来锁定查询结果,或者通过LOCK TABLES命令来锁定整个表。当一个事务访问了数据并加锁后,其他事务就不能再访问该数据,直到当前事务释放锁为止。

select语句  +for update;

缺点是会影响并发性和性能,因为它会阻塞其他等待访问该数据的事务。因此,通常只在需要确保数据一致性和安全性的场景下使用。


死锁

事务之间相互等待对方资源,最后形成一个闭环
情况1、发生死锁时,数据库对自动选择一个受害者,然后先接触死锁,然后再回滚事务;
情况2:mysql的默认的死锁机制,会中选择一个事务作为死锁的牺牲品。直接终止,其中一个事务,但不会自动回滚。


乐观锁

不会任何提示,只是数据不能写入。数据提交更新时,进行校验,发生冲突,数据不生效而已,没有报错或者卡顿。

应用场景:通常适用于并发量较高的场景

乐观锁的实现方式有多种,其中比较常见的是使用版本号或时间戳来判断数据是否被修改。

假设数据是不会被并发访问的,因此在修改数据时不加锁,而是在更新时比较数据版本号,如果版本号一致,则表示此间隙内没有其他线程修改该数据,可以进行更新操作,如果版本号不一致,则表示数据已被其他线程修改,需要进行回滚或其它处理。


如何尽可能地避免死锁:

1、优化业务逻辑:业务的逻辑要合理,以固定的顺序问表和行
2、尽量使用短事务:如果事务的类型比较复杂,要进行拆分,在业务允许额情况下,把大事务拆小。
3、在同一事务中,尽可能一次性锁定所有需要的资源,可以减少死锁地概率
4、隔离级别,read commit可以尽可能的避免死锁
5、建立良好的索引:添加合理索引,可以减少死锁的概率

6、设置超时时间:设置锁的超时时间,当超过一定时间限制时,强制终止锁的持有者的操作,以避免死锁。

7、定期监测:对于数据库管理员来说,定期监测死锁的发生情况,可以及时处理和优化数据库,以降低死锁的发生率和影响。

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

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

相关文章

uniapp原生插件之安卓文件操作原生插件

插件介绍 安卓文件操作原生插件,读写文件,文件下载等,支持读取移动设备路径等外部存储设备路径,如U盘路径 插件地址 安卓文件操作原生插件 - DCloud 插件市场 超级福利 uniapp 插件购买超级福利 详细使用文档 uniapp 安卓文…

互联网医院|湖南互联网医院|智慧医疗改善就医服务

互联网医院系统,是指利用互联网技术和远程医疗技术,提供在线就诊、咨询、诊断和治疗等医疗服务的一种医疗模式。互联网医院系统实际上与医院的HIS系统很相似,是侧重服务于线上问诊的专业HIS,包含传统HIS的基本模块,如挂…

VS Code 开发 Spring Boot 类型的项目

在VS Code中开发Spring Boot的项目, 可以导入如下的扩展: Spring Boot ToolsSpring InitializrSpring Boot Dashboard 比较建议的方式是安装Spring Boot Extension Pack, 这里面就包含了上面的扩展。 安装方式就是在扩展查找 “Spring Boot…

【工具】【IDE】Qt Creator社区版

Qt Creator社区版下载地址:https://download.qt.io/archive/qt/ 参考:https://cloud.tencent.com/developer/article/2084698?areaSource102001.8&traceIduMchNghqp8gWPdFHvSOGg MAC安装并配置Qt(超级简单版) 1.安装brew&…

精品Python手机选购决策数据的分析与可视化大屏购物商城-爬虫

《[含文档PPT源码等]精品基于Python的手机选购决策数据的分析与可视化-爬虫》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程、包运行成功! 软件开发环境及开发工具: 开发语言:python 使用框架:Django …

2023-mac rz sz 安装

之前安装过一次,没问题,这次按照之前教程装了就不管上传下载都会卡住; step1: brew install lrzsz step2:在/usr/local/bin 路径下配置两个sh,之前从网上找到的直接用都不对,下面这个是调试过的正式可用的 iterm2…

堆叠注入 [GYCTF2020]Blacklist1

打开题目 判断注入点 输入1,页面回显 输入1 页面报错 输入 1 # 页面正常,说明是单引号的字符型注入 我们输入1; show databases; # 说明有6个数据库 1; show tables; # 说明有三个表 我们直接查看FlagHere的表结构 1;desc FlagHere;# 发…

『PyQt5-基本控件』| 16 什么是屏幕坐标系?

16 什么是屏幕坐标系? 1 什么是屏幕坐标系?2 相关概念3 代码实现4 获取窗口坐标4.1 直接获取4.2 通过坐标系获取4.3 获取Frame坐标1 什么是屏幕坐标系? 2 相关概念 屏幕坐标系,即窗口相对于屏幕的坐标。屏幕左上角坐标称为原点坐标(0,0);窗口的坐标,即窗口的左上角相对…

uniapp在APP端使用swiper进行页面不卡顿滑动

uniapp在APP端使用swiper进行页面会卡顿&#xff0c;主要是渲染的数据有点多&#xff0c;这里只渲染三个数据就不好那么卡顿了&#xff0c;每次滑动后更新数据 <view><swiper change"changePoint" circular :disable-touch"disableTouch"><…

速卖通新卖家有必要测评吗?

大家都知道通过测评可以提升产品的转化率&#xff0c;提升产品的销量&#xff0c;那么做速卖通的卖家有必要测评吗&#xff1f; 测评就是类似于国内电商的补单&#xff0c;而一个类目里面竞争很大很卷的话&#xff0c;不去补销量来提升产品的权重&#xff0c;凭借着平台给的自…

静态链表的定义与实现(数据结构与算法)

1. 静态链表 用数组的方式实现的链表 单链表&#xff1a; 各个结点在内存中星罗棋布、散落天涯 静态链表&#xff1a;分配一整片连续的内存空间&#xff0c; 各个结点集中安置。 1.1 静态链表的优点 不需要像动态链表那样频繁地进行内存分配和释放&#xff0c;可以节省内存…

2010年408计网

下列选项中, 不属于网络体系结构所描述的内容是&#xff08;C&#xff09;A. 网络的层次B. 每层使用的协议C. 协议的内部实现细节D. 每层必须完成的功能 本题考查网络体系结构的相关概念 再来看当今世界最大的互联网&#xff0c;也就是因特网。它所采用的TCP/IP 4层网络体系结…

Java自学第2课:Java语言基础知识要点

1 Java主类结构 任务&#xff1a;创建新项目名为item&#xff0c;包名为number&#xff0c;类名为first。 1.1 包声明 不指定包时&#xff0c;默认就是工程名&#xff0c;指定后&#xff0c;类文件可以分类了&#xff0c;是这意思吧。包就大概等于一个文件夹。而且在类文件中…

PS学习笔记合集

2.一些快捷键 一、放大快捷键 Ctrl&#xff1a;在画布中点击一次&#xff0c;即可放大一次&#xff0c;可多次点击。 CtrlShift&#xff1a;在画布中点击一次&#xff0c;即可放大到适合窗口大小。 CtrlAlt&#xff1a;在画布中点击一次&#xff0c;即可放大到适合窗口大小&a…

爱写bug的小邓程序员个人博客

博客网址: http://www.006969.xyz 欢迎来到我的个人博客&#xff0c;这里主要分享我对于前后端相关技术的学习笔记、项目实战经验以及一些技术感悟。 在我的博客中&#xff0c;你将看到以下主要内容&#xff1a; 技术文章 我将会分享我在学习前后端技术过程中的一些感悟&am…

基于单片机的可穿戴个人健康监测仪-智能手环

收藏和点赞&#xff0c;您的关注是我创作的动力 文章目录 概要 一、方案的设计与论证2.1设计任务及要求2.2 模块技术和方法综述2.3 设计可能遇到的困难 二、 系统总体框架3.1 硬件设计 三 软件部分4.1 主程序流程框 四、 结论五、 文章目录 概要 近几年智能化的不断发展&#…

JavaEE平台技术——预备知识(Web、Sevlet、Tomcat)

JavaEE平台技术——预备知识&#xff08;Web、Sevlet、Tomcat&#xff09; 1. Web基础知识2. Servlet3. Tomcat并发原理 1. Web基础知识 &#x1f192;&#x1f192;上个CSDN我们讲的是JavaEE的这个渊源&#xff0c;实际上讲了两个小时的历史课&#xff0c;给大家梳理了一下&a…

计算机组成与结构-计算机体系结构

计算机体系结构 指令系统 Flynn分类法 SISD&#xff08;单指令流单数据流&#xff09; 结构 控制部分&#xff1a;一个处理器&#xff1a;一个主存模块&#xff1a;一个 代表 单处理器系统 SIMD&#xff08;单指令流多数据流&#xff09; 结构 控制部分&#xff1a;一个处理…

C++ 算法:区间和的个数

涉及知识点 归并排序 题目 给你一个整数数组 nums 以及两个整数 lower 和 upper 。求数组中&#xff0c;值位于范围 [lower, upper] &#xff08;包含 lower 和 upper&#xff09;之内的 区间和的个数 。 区间和 S(i, j) 表示在 nums 中&#xff0c;位置从 i 到 j 的元素之和…

基于单片机设计的电子柜锁

一、前言 随着现代社会的不断发展&#xff0c;电子柜锁的应用越来越广泛。传统的机械柜锁存在一些不便之处&#xff0c;例如钥匙容易丢失、密码容易泄露等问题。设计一款基于单片机的电子柜锁系统成为了一个有趣而有意义的项目。 该电子柜锁系统通过电磁锁作为柜锁的开关&…