高性能MySQL基础总结(读书随笔)

两种最重要的锁策略

表锁和行锁

  • 表锁是MySQL中最基本的锁策略,而且是开销最小的策略,它会锁定整张表

    一个用户在对表进行写操作前,需要先获得写锁,这会阻塞其他用户对该表的所有读写操作。只有没有写锁时,其他读取的用户才能获得读锁,读锁之间是不互相阻塞的。

    尽管存储引擎可以管理自己的锁,MySQL本身还是会使用各种有效的表锁来实现不同的目的。例如,服务器会为诸如Alter Table之类的语句使用表锁,而忽略存储引擎的锁机制。

  • 行级锁可以最大程度的支持并发处理(同时也带来了最大的锁开销)。InnoDB中实现了行级锁。

    行级锁只在存储引擎层实现,而MySQL数据库层没有实现。服务器层完全不了解存储引擎中的锁实现。

事务ACID

事务内的语句,要么全部执行成功,要么全部执行失败。
事务的特性ACID。

  • 原子性(atomicity)

    一个事务必须被视为一个不可分割的最小工作单元,整个事务中的所有操作要么全部提交成功,要么全部失败回滚,对于一个事务来说,不可能只执行其中的一部分操作,这就是事务的原子性。

  • 一致性(consistency)

    数据库总是从一个一致性的状态转换到另外一个一致性的状态。即使我们的操作执行一半系统崩溃,因为事务最终没有提交,所以事务中所做的修改也不会保存到数据库中。

  • 隔离性(isolation)

    一个事务所做的修改在最终提交之前,对其他事务是不可见的。

  • 持久性(durability)

    一旦事务提交,则其所做的修改就会永久保存到数据库中。此时即使系统崩溃,修改的数据也不会丢失。

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