MySQL 索引&事务

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 作用

  • 索引所起的作用类似书籍目录,可用于快速定位、检索数据

  • 索引对于提高数据库的性能有很大的帮助

    MySQL 索引&事务_第1张图片

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;
    

    MySQL 索引&事务_第2张图片

  • 创建索引

    对于非主键、非唯一约束、而非外键的字段,可以创建普通索引

    create index 索引名 on 表名(字段名)
    

    案例:创建班级表中,name字段的索引

    create index idx_classse on classes;
    

    MySQL 索引&事务_第3张图片

  • 删除索引

    drop index 索引名 on 表名;
    

    案例:删除班级表中name字段的索引

    drop index idx_classes_name on classes;
    

    MySQL 索引&事务_第4张图片

注:索引并不是一种直接调用的方法,而是一种提高查询效率的方式

在创建索引前,数据查询是按顺序遍历查询的,一旦数据量过大,则查询效率会很低:

在这里插入图片描述

为此我们可以创建一个索引,再次调用查询后会先自动搜索对应索引来查找数据,以此提高我们的查询效率:

MySQL 索引&事务_第5张图片

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);

MySQL 索引&事务_第6张图片

这时,四十大盗从阿里巴巴的账户上偷盗了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 使用

  1. 开启事务:start transaction;
  2. 执行多条SQL语句
  3. 回滚或提交: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;

MySQL 索引&事务_第7张图片

你可能感兴趣的:(MySQL,数据库,mysql,数据库)