MySQL 索引&事务
文章目录
- MySQL 索引&事务
- 1. 索引
- 1.1 概念
- 1.2 作用
- 1.3 使用场景
- 1.4 使用
- 2. 事务
- 2.1 为什么使用事务
- 2.2 事务概念
- 2.3 事务的特性
- 2.4 使用
1. 索引
1.1 概念
索引(index)是一种特殊的文件,包含着对数据表里所有记录的引用指针。可以对表中的一列或多列创建索引,并指定索引的类型。
1.2 作用
-
索引所起的作用类似书籍目录,可用于快速定位、检索数据
-
索引对于提高数据库的性能有很大的帮助
1.3 使用场景
要对数据库表的某列或某几列创建索引,需要考虑以下几点:
- 数据量较大,且需要经常对数据进行条件查询
- 对列的修改操作频率低(插入,删除,修改)
满足以上条件时,可以考虑对表中的这些字段创建索引,以提高查询效率
反之,如果对非条件查询列、经常做插入、修改操作、磁盘空间不足的情况,不考虑创建索引
1.4 使用
我们在创建主键约束(PRIMARY KEY)、唯一约束(UNIQUE)、0外键约束(FOREIGN KEY)时,会自动创建对应列的索引
-
查看索引
show index from 表名
案例:查看班级表已有的索引
--创建主键时会产生索引--此时索引名为PRIMARY create table classes (idx_classex int primary key auto_increment, name varchar(20)); show index from classes;
-
创建索引
对于非主键、非唯一约束、而非外键的字段,可以创建普通索引
create index 索引名 on 表名(字段名)
案例:创建班级表中,name字段的索引
create index idx_classse on classes;
-
删除索引
drop index 索引名 on 表名;
案例:删除班级表中name字段的索引
drop index idx_classes_name on classes;
注:索引并不是一种直接调用的方法,而是一种提高查询效率的方式
在创建索引前,数据查询是按顺序遍历查询的,一旦数据量过大,则查询效率会很低:
为此我们可以创建一个索引,再次调用查询后会先自动搜索对应索引来查找数据,以此提高我们的查询效率:
2. 事务
2.1 为什么使用事务
我们先准备一个测试表:
create table account (id int primary key auto_increment;name varchar(20),money decimal(11, 2)
);insert into account(name, money) values ('阿里巴巴', 5000), ('四十大盗', 1000);
这时,四十大盗从阿里巴巴的账户上偷盗了2000元
-- 阿里巴巴账户减少2000
update account set money = money - 2000 where name = '阿里巴巴';
-- 四十大盗账户增加2000
update account set money = money + 2000 where name = '四十大盗';
假如在执行以上第一句SQL时,出现网络错误,或者是数据库挂掉了,阿里巴巴的账户会减少2000元,但是四十大盗的账户上就没有了增加的金额
解决方案:使用事务来控制,保证以上两句SQL语句要么全部执行成功,要么全部执行失败
2.2 事务概念
事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部失败
在不同的环境下,都可以有事务,对应在数据库中,就是数据库事务
2.3 事务的特性
- 原子性:指事务是一个不可分割的最小工作单位,事务中的操作只有都发生和都不发生两种情况
- 一致性:事务必须要使数据库从一个一致状态变换为另一个一致状态,且中间变换的过程其它事务不可见。如:阿里巴巴被四十大盗偷了1000元,其事务就是阿里巴巴账户上少了1000元,四十大盗上多了1000元。因为一致性的影响其它事务看到的情况要么是阿里巴巴还没少1000元的情况,要么就是四十大盗成功偷到阿里1000元的情况,至于中间阿里少了1000元而四十大盗还没加上1000元这个中间状态是不可见的
- 隔离性:一个事务的执行不能被其它事务干扰,即一个事务内部的操作及使用的数据对并发的其它事务是隔离的,并发执行的各个事务之间不能互相干扰
- 持久性:一个事务一旦提交成功,它对数据库中数据的改变将是永久性的
2.4 使用
- 开启事务:
start transaction
; - 执行多条SQL语句
- 回滚或提交:
rollback/commit
;(rollback一般配合条件判断语句使用)
注:rollback
代表从start transaction到rollback位置下语句全部执行失败,commit
代表从start transaction到commit下语句全部执行成功
start transaction;
-- 阿里巴巴账户减少2000
update account set money = money - 2000 where name = '阿里巴巴';
-- 四十大盗账户增加2000
update account set money = money + 2000 where name = '四十大盗';
commit;