(1)可重复读的核心就是一致性读(consistent read);保证多次读取同一个数据时,其值都和事务开始时候的内容是一致,禁止读取到别的事务未提交的数据,会造成幻读。
(2)而事务更新数据的时候,只能用当前读。如果当前的记录的行锁被其他事务占用的话,就需要进入锁等待。
(3)查询只承认在事务启动前就已经提交完成的数据。
(4)可重复读解决的是重复读的问题,可重复读在快照读的情况下是不会有幻读,但当前读的时候会有幻读。
(1)分析语句,是否加载了不必要的字段/数据。
(2)分析 SQL 执行计划(explain extended),思考可能的优化点,是否命中索引等。
(3)查看 SQL 涉及的表结构和索引信息。
(4)如果 SQL 很复杂,优化 SQL 结构。
(5)按照可能的优化点执行表结构变更、增加索引、SQL 改写等操作。
(6)查看优化后的执行时间和执行计划。
(7)如果表数据量太大,考虑分表。
(8)利用缓存,减少查询次数。