MyISAM和InnoDB
建立索引情况
事务四大特性
原子性,一致性,隔离性,持久性
事务具有四个特征:原子性( Atomicity )、一致性( Consistency )、隔离性( Isolation )和持续性( Durability )。这四个特性简称为 ACID 特性。
1 、原子性。事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做
2 、一致性。事 务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是 不一致的状态。
3 、隔离性。一个事务的执行不能其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
4 、持续性。也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
MySQL四种隔离级别(默认是可重复读,oracle只有已提交读和可串行化,默认是已提交读)
读未提交
A事务读取B事务未提交的修改 ,造成脏读
读已提交(Oracle默认)
已提交读隔离级别解决了脏读的问题,但是出现了不可重复读的问题,即事务A在两次查询的数据不一致,因为在两次查询之间事务B更新了一条数据。已提交读只允许读取已提交的记录,但不要求可重复读。
可重复读(MySQL默认)
解决了不可重复读 但出现幻读,比如查询工资大于5K的记录数,第二次查询之前,B事务插入了一条并提交,A事务两次查询的结果不一样,出现幻读。
可串行化
A事务更新时进入等待状态,等待B事务提交,serializable完全锁定字段,若一个事务来查询同一份数据就必须等待,直到前一个事务完成并解除锁定为止。是完整的隔离级别,会锁定对应的数据表格,因而会有效率的问题。
索引失效
口诀
优化总结口诀
全值匹配我最爱, 最左前缀要遵守;
带头大哥不能死, 中间兄弟不能断;
索引列上少计算, 范围之后全失效;
LIKE 百分写最右, 覆盖索引不写 *;
不等空值还有 OR, 索引影响要注意;
VAR 引号不可丢, SQL 优化有诀窍。
innodb 行锁
mysql 更新操作时,命中索引则行锁,不命中索引则表锁。
间隙锁(了解)
explain
id
id相同 顺序从上往下, id越大越先执行
select_type
type
最好到最坏
system,const,eq_ref,ref,range,index,all --至少达到range,最好到达ref
EXTRA
using filesort:排序用不到索引,要优化。 using index 覆盖索引 select a1,a2 from a; 不适用select *