MySQL索引、事务、锁

一、索引

1. 什么是索引?
一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结构。
2.索引的作用?
索引在 MySQL 中也叫做“键”,是存储引擎用于快速找到记录的一种数据结构。
索引对于良好的性能非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要。
3.索引的优劣势
优势
可以快速检索,减少 I/O 次数,加快检索速度;根据索引分组和排序,可以加快分组和排序。
劣势
1.索引本身也是表,会占用存储空间,索引表占用的空间是数据表的 1.5 倍;
2.索引表的维护和创建随着数据量增大而增大;
3.构建索引会降低数据表的删除,添加,修改的效率,因为修改数据表的同时还需要修改索引表。
4.索引的使用
创建索引
1)创建表时建立索引

create table 表名( 字段名 字段类型 约束, index 索引名称 (字段名(字段长度)) );

2)创建表后建立索引

create index 索引名 on 表名(字段名(字段长度)); 
或者
alter table 表名 add index 索引名(字段名(字段长度));

查找索引

show index from 表名;

删除索引

drop index 索引名称 on 表名;
或者
alter table 表名 drop index 索引名;

5.常见的索引类型
索引类型:主键索引、唯一索引、普通索引、全文索引、组合索引。

二、事务

1.什么是事务?
最小的不可再分的工作单元;通常一个事务对应一个完整的业务(例如银行账户转账业务,
该业务就是一个最小的工作单元)。
2.事务的应用有哪些?
1)开启事务:

start transaction;
或者
begin transaction;

2)提交事务:

commit;

3)回滚事务:

rollback;

3.事务的四大特征(ACID)

原子性:事务是最小单位,不可再分;
一致性:事务要求所有的 DML 语句操作的时候,必须保证同时成功或者同时失败;
隔离性:同一时间,只允许一个事务请求同一数据,不同的事务之间彼此没有任何干扰;
持久性:是事务的保证,事务终结的标志(内存的数据持久到硬盘文件中)。

4.事务的隔离级别
读未提交(read uncommitted) :事务 A 和事务 B,事务 A 未提交的数据,事务 B 可以读取到,这里读
取到的数据叫做“脏数据”。这种隔离级别最低,一般是在理论上存在,数据库隔离级别一般都高于该
级别;
读已提交(read committed) :事务 A 和事务 B,事务 A 提交的数据,事务 B 才能读取到。这种隔离级
别高于读未提交,可以避免“脏数据”。但如果事务 A 多次读取同一数据,而事务 B 在事务 A 多次读
取的过程中,对数据作了更新并提交,导致事务 A 多次读取同一数据时,结果不一致,这种现象称为“不
可重复读”;
可重复读(repeatable read): 事务 A 和事务 B,事务 A 提交之后的数据,事务 B 读不到事务 A 提交
的数据。这种隔离级别高于读已提交,但如果事务 A 在修改数据的过程中(比如将所有记录状态设为 1),
如果事务 B 向同一张表中插入一条新记录(状态为 0),事务 A 提交后再次查询表,会发现有一条记录
状态没有改成 1,好像发生了幻觉,这种现象称为“幻读”。可重复读是 MySQL 默认隔离级别;
串行化(serializable):事务 A 和事务 B,事务 A 在操作数据库时,事务 B 只能排队等待。这种级别
可以避免“幻读”,每一次读取的都是数据库中真实存在数据,事务 A 与事务 B 串行,而不并发。
在这里插入图片描述
总结 :隔离级别越高,越能保证数据的完整性和一致性,但是对并发性能的影响也越大。对于多数应用程序,
可以优先考虑把数据库系统的隔离级别设为 Read Committed,它能够避免脏读取,而且具有较好的并发性能。
尽管它会导致不可重复读、幻读这些并发问题,在可能出现这类问题的个别场合,可以由应用程序采用悲观锁
或乐观锁来控制。

三、锁

1、乐观锁
乐观锁不是数据库自带的,需要我们自己去实现。乐观锁是指操作数据库时(更新操作),想法很乐观,认为这次的操作不会导致冲突,在操作数据时,并不进行任何其他的特殊处理(也就是不加锁),而在进行更新后,再去判断是否有冲突了。
2、悲观锁
与乐观锁相对应的就是悲观锁了。悲观锁就是在操作数据时,认为此操作会出现数据冲突,所以在进行每次操作时都要通过获取锁才能进行对相同数据的操作,这点跟 java 中的 synchronized 很相似,所以悲观锁需要耗费较多的时间。另外与乐观锁相对应的,悲观锁是由数据库自己实现了的,要用的时候,我们直接调用数据库的相关语句就可以了。
1) 共享锁与排它锁
共享锁(S):也称为读锁,允许事务读取一行数据。例如事务 T 对数据对象 A 加上 S 锁,则事务 T 可以读 A但不能修改 A,其他事务只能再对 A 加 S 锁,而不能加 X 锁,直到 T 释放 A 上的 S 锁。这保证了其他事务可以读A,但在 T 释放 A 上的 S 锁之前不能对 A 做任何修改。排它锁(X):也称写锁,允许事务删除或更新一行数据。例如事务 T 对数据对象 A 加上 X 锁,事务 T 可以读A 也可以修改 A,其他事务不能再对 A 加任何锁,直到 T 释放 A 上的锁。
2) 锁的粒度
锁的粒度就是你要锁定的范围是多大。使用锁时,锁定的东西越少,对其他竞争者影响越小,这个东西的大小就是锁粒度。
锁的粒度分类:
表级锁:开销小,加锁快,不会出现死锁。锁定粒度最大,适合查询为主的,只有少量按索引条件更新数据的操作。缺点是资源争用概率高;
行级锁:开销大,加锁慢,会出现死锁。锁定粒度最小,适合大量按索引条件并发更新少量不同数据,同时又有并发查询的操作。使用行级锁定的主要是 InnoDB 存储引擎;
页面锁:开销介于表锁与行锁之间,会出现死锁。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值