1、索引简介

  1. 什么是索引?
    一般的应用系统,读写比例在 10:1 左右,而且插入操作和一般的更新操作很少出现性能问题,在生产环境 中,我们遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,因此对查询语句的优化显然是重中之重。 说起加速查询,就不得不提到索引了。
  2. 为什么要有索引?
    索引在 MySQL 中也叫做“键”,是存储引擎用于快速找到记录的一种数据结构。
  3. 索引的优劣势:
    索引的优势:可以快速检索,减少 I/O 次数,加快检索速度;根据索引分组和排序,可以加快分组和排序。
    索引的劣势:索引本身也是表,因此会占用存储空间,一般来说,索引表占用的空间是数据表的 1.5 倍;索 引表的维护和创建需要时间成本,这个成本随着数据量增大而增大;构建索引会降低数据表的修改操作(删除, 添加,修改)的效率,因为在修改数据表的同时还需要修改索引表。
    3, MySQL 中索引的使用
  4. 创建索引

    在创建表之后创建索引

    查看索引

    删除索引

    通过 EXPLAIN 分析 SQL 是否使用到索引

    MySQL 中事务的使用
  5. 开启事务
  6. 提交事务
  7. 回滚事务

    下面是个案例

    运行结果如下

    事务的特征
    读未提交(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 串行,而不并发

mysql 锁在索引上 mysql锁与索引_索引