首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Mysql锁--mysql详解(十二

上篇文章说了mvcc保证事务隔离性,隔离有脏读,不可重复读,幻读,而mysql有四种隔离级别,read uncommit,read commit,repeatable read,serializable...,解决这些问题,mysql新版本默认是可重复读,利用mvcc解决幻读,read view链表组成有m_ids活跃事务id,最大事务id和最小事务id以及当前事务id,解决的是快照读,当前读还是会存在一定问题...Mvcc--mysql详解(十一) Mysql锁 首先我们知道读的时候是不需要加锁的,当几个线程同时写入的时候,操作同一条数据,修改数据的那个事务就会生成锁。...表的颗粒分为行锁和表锁,行锁上的就是s锁和x锁,当整个表上锁的时候,其他事务应该也是不可以访问的,这时候怎么知道他上了表锁呢,或者循环他吗,当然不是,mysql设置了意向锁,is锁和ix锁,当表上了ix...Lock_gap锁:前面说过mysql在repeatable read隔离下解决幻读要么加锁,要么mvcc读加写锁,但是加锁的时候还会存在问题,防止在两个值得间隙插入锁,这个锁又叫间隙锁。

24220

MySQL十二:索引分析

一、执行计划(EXPLAIN) MySQL 提供了一个 EXPLAIN 命令,它「可以对 sql语句进行分析,并输出sql执行的详细信息」,可以让我们有针对性的优化。...例如: explain select * from student where id > 2; 这里需要注意一下版本差异 「MySQL 5.6.3」 MySQL 5.6.3以前只能 EXPLAIN...SELECT ;MYSQL 5.6.3以后可以 EXPLAIN SELECT,UPDATE,DELETE 「MySQL 5.7」 MySQL 5.7以前想要显示 partitions 需要使用...子句中索引列使用了表达式,包括函数表达式 #对应(age)索引 explain select id from user order by abs(age); 5.3排序算法 filesort有两种排序算法:路排序和单路排序...路排序:需要两次磁盘扫描读取,得到最终数据。第一次将排序字段读取出来,然后排序;第二 次去读取其他字段数据。 单路排序:从磁盘查询所需的所有列数据,然后在内存排序将结果返回。

1.3K20
领券