mysql索引与锁的关系_关系型数据库(索引与锁)

设计一个关系型数据库

84fdb832fe11

图片.png

索引模块

为什么要使用索引

查询时间复杂度从O(n)提升到O(logn)

84fdb832fe11

图片.png

存在以下弊端,并且会多次io,影响速度。

84fdb832fe11

图片.png

采用B Tree

B tree(多路搜索树,并不是二叉的)是一种常见的数据结构。使用B-tree结构可以显著减少定位记录时所经历的中间过程,从而加快存取速度。按照翻译,B 通常认为是Balance的简称。这个数据结构一般用于数据库的索引,综合效率较高。

84fdb832fe11

图片.png

84fdb832fe11

图片.png

蓝色的关键字的个数永远比黄色的孩子个数少一个

B+ Tree

84fdb832fe11

图片.png

优势:

1、B+ 树磁盘读写代价更低(叶子结点有多个值, 不用频繁io读取)

2、B+ 树查询效率更加稳定(从根节点到叶子节点长度固定,时间复杂度o(log n))

3、B+ 树叶子节点有指针链接,更有利于对数据库的扫描

Hash索引

84fdb832fe11

图片.png

BitMap索引

84fdb832fe11

图片.png

主流是B+树还有哈希索引 bitmap位图索引(锁的问题需要考虑)

oracle支持

密集索引与稀疏索引

区别

1、密集索引文件中每个搜索码值都对应一个索引值

2、稀疏索引只为索引码的某些值建立索引项

84fdb832fe11

图片.png

如何定位并优化慢查询sql

1、根据慢日志定位慢查询sql

2、使用explain等工具分析sql

3、修改sql或者尽量让sql走索引

mysql

show variables like '%quer%';

84fdb832fe11

图片.png

show status like '%slow_queries%';

set global slow_query_log = on;

set global long_query_time = '1';

使用explain select name from person order by name desc;

force index 强制使用某种索引

84fdb832fe11

图片.png

联合索引最左匹配原则

84fdb832fe11

图片.png

锁模块

MyISAM默认用的是表级锁,不支持行级锁 (锁整张表,相当于不能并发执行,读锁没有执行完毕,不能进行写锁操作)

InnoDB默认用的是行级锁,也支持表级锁

mysql默认自动提交事务

for update 或者增删改排他锁(写锁)

查询 共享锁(读锁)

84fdb832fe11

图片.png

84fdb832fe11

图片.png

84fdb832fe11

图片.png

84fdb832fe11

图片.png

84fdb832fe11

图片.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
课程简介: 课程总计41课时,从什么是事务讲起,直到分布式事务解决方案,很的0基础基础与提升系列课程。对于难以理解的知识点,全部用画图+实战的方式讲解。 第一部分:彻底明白事务的四个特性:原子性、一致性、隔离性、持久性,用场景和事例来讲解。 第二部分:实战讲数据库事务的6中并发异常:回滚丢失、覆盖丢失、脏读、幻读、不可重复读、MVCC精讲。 第三部分:彻底搞清楚4种事务隔离级别:READ_UNCOMMITTED 读未提交隔离级别、READ_COMMITTED 读已提交隔离级别、REPEATABLE_READ 可重复度隔离级别、SERIALIZABLE 序列化隔离级别 第四部分:彻底搞清楚MySQL的各种:行、表、共享、排它、Next-Key、间隙、X、S、IS、IX、死索引、意向等。 第五部分:彻底搞清楚Spring事务的7种传播级别的原理和使用:PROPAGATION_REQUIRED、PROPAGATION_SUPPORTS、PROPAGATION_MANDATORY、PROPAGATION_REQUIRES_NEW、PROPAGATION_NOT_SUPPORTED、PROPAGATION_NEVER、PROPAGATION_NESTED分布式事务的理论基础:RPC定理、BASE理论、XA协议都是什么,原理是什么,有什么关联关系 第六部分:分布式事务的5种解决方案原理和优缺点:2PC两阶段提交法、3PC三阶段提交法、TCC事务补偿、异步确保策略、最大努力通知策略 第七部分:阿里巴巴分布式事务框架Seata:历经多年双十一,微服务分布式事务框架,用一个Nacos+Spring Cloud+Seta+MySql的微服务项目,实战讲解阿里的分布式事务技术,深入理解和学习Seata的AT模式、TCC模式、SAGA模式。 课程资料: 课程附带配套2个项目源码72页高清PDF课件一份阿里巴巴seata-1.1.0源码一份阿里巴巴seata-server安装包一份

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值