1.2 并发控制
1.2.1读写锁
在处理并发读或写时,通过实现一个由两种类型的锁组成的锁系统来解决问题。这两种类型的锁通常被称为 共享锁(shared lock) 和 排它锁(exclusive lock),也叫读锁(read lock)和写锁(write lock)。
读锁是共享的,或者说是不互相阻塞的。多个客户端可以在同一时刻读取同一个资源,而互不干扰。写锁则是排他的,也就是说一个写锁会阻塞其他写锁和读锁。
1.2.2锁粒度
为了提高共享资源的并发性,尽量只锁定需要修改的部分数据,而不是所有数据。
表锁(table lock)
表锁是MySQL中最基本的锁策略,并且是开销最小的策略。进行写操作(插入、删除、更新等)先需要获得写锁,这会阻塞其他用户对该表的所有读写操作。读锁之间是不相互阻塞的。写锁有比读锁更高的优先级,因此一个写锁请求可能会被插入到读锁队列的前面(写锁可以插入到锁队列的前面,反之读锁则不能插入到写锁的前面)。
ALTER TABLE之类的语句会使用表锁,并且会忽略存储引擎的锁机制。
行级锁(row lock)
行级锁可以最大限度的支持并发处理,但同时也到来了最大的锁开销。MySQL的InnoDB和XtraDB等存储引擎实现了行级锁。行级锁只在存储引擎层面实现,并且服务器层完全不了解存储引擎中的锁实现。
1.3事务
事务就是一组原子性的SQL查询,这组查询要么全部执行成功,要么全部执行失败。
事务的ACID概念:
原子性(atomicity):一个事务必需被视为一个不可分割的最小工作单元。
一致性(consistency):
隔离性(i