索引下推:MySQL 5.6引入了索引下推优化 , 可以在索引遍历过程中,对索引中包含的字段先做判断 , 过滤掉不符合条件的记录,减少回表字数 。
索引维护:B+树为了维护索引有序性涉及到页分裂跟页合并 。增删数据时需考虑页空间利用率 。
自增主键:一般会建立与业务无关的自增主键,不会触发叶子节点分裂 。
延迟关联:通过使用覆盖索引查询返回需要的主键,再根据主键关联原表获得需要的数据 。
InnoDB存储: * .frm文件是一份定义文件,也就是定义数据库表是一张怎么样的表 。*.ibd文件则是该表的索引,数据存储文件,既该表的所有索引树 , 所有行记录数据都存储在该文件中 。
MyISAM存储:* .frm文件是一份定义文件 , 也就是定义数据库表是一张怎么样的表 。* .MYD文件是MyISAM存储引擎表的所有行数据的文件 。* .MYI文件存放的是MyISAM存储引擎表的索引相关数据的文件 。MyISAM引擎下,表数据和表索引数据是分开存储的 。
MyISAM查询:在MyISAM下,主键索引和辅助键索引都属于非聚簇索引 。查询不管是走主键索引,还是非主键索引 , 在叶子结点得到的都是目的数据的地址,还需要通过该地址,才能在数据文件中找到目的数据 。
PS:InnoDB支持聚簇索引,MyISAM不支持聚簇索引
4、SQL事务隔离级别
ACID的四个特性
原子性(Atomicity):把多个操作放到一个事务中,保证这些操作要么都成功 , 要么都不成功
一致性(Consistency):理解成一串对数据进行操作的程序执行下来,不会对数据产生不好的影响,比如凭空产生,或消失
隔离性(Isolation,又称独立性):隔离性的意思就是多个事务之间互相不干扰,即使是并发事务的情况下,他们只是两个并发执行没有交集,互不影响的东西;当然实现中,也不一定需要这么完整隔离性,即不一定需要这么的互不干扰,有时候还是允许有部分干扰的 。所以MySQL可以支持4种事务隔离性
持久性(Durability):当某个操作操作完毕了,那么结果就是这样了 , 并且这个操作会持久化到日志记录中
PS:ACID中C与CAP定理中C的区别
ACID的C着重强调单数据库事务操作时 , 要保证数据的完整和正确性,数据不会凭空消失跟增加 。CAP 理论中的C指的是对一个数据多个备份的读写一致性
事务操作可能会出现的数据问题
1、脏读(dirty read):B事务更改数据还未提交 , A事务已经看到并且用了 。B事务如果回滚,则A事务做错了
2、 不可重复读(non-repeatable read):不可重复读的重点是修改: 同样的条件, 你读取过的数据, 再次读取出来发现值不一样了 , 只需要锁住满足条件的记录
【mysql怎么维护索引 mysql索引实现原理】 3、 幻读(phantom read):事务A先修改了某个表的所有纪录的状态字段为已处理,未提交;事务B也在此时新增了一条未处理的记录,并提交了;事务A随后查询记录 , 却发现有一条记录是未处理的造成幻读现象,幻读仅专指新插入的行 。幻读会造成语义上的问题跟数据一致性问题 。
4、 在可重复读RR隔离级别下,普通查询是快照读,是不会看到别的事务插入的数据的 。因此,幻读在当前读下才会出现 。要用间隙锁解决此问题 。
在说隔离级别之前,你首先要知道 , 你隔离得越严实,效率就会越低 。因此很多时候,我们都要在二者之间寻找一个平衡点 。SQL标准的事务隔离级别由低到高如下: 上图从上到下的模式会导致系统的并行性能依次降低,安全性依次提高 。
推荐阅读
- 南阳直播录屏,南阳市视频
- ps4的游戏是网络游戏吗,ps4游戏是主机游戏吗
- 套路益智游戏下载,套路游戏版
- html字体加粗属性标签,html中字体加粗属性
- nvidia显卡设置怎么设置,nvidia显卡怎么设置最好
- 下载课本的软件,下载课本电子书有什么好的软件
- c语言有调用关系的函数 c语言程序中有调用关系的函数必须放在
- 电脑磁盘损坏怎么设置,电脑磁盘加密
- 餐饮公众号首次关注回复语,关注公众号点餐