1.系统要通过严格的ACID测试,ACID表示原子性/一致性/隔离性/持久性
原子性:一个事务必须被视为一个不可分割的最小工作单元
一致性:数据库总是从一个一致性的状态转换到另外一个一致性的状态
隔离性...:通常来说一个事务所做的修改在最终提交以前对其他事务是不可见的
持久性:一旦事务提交,则其所做的修改就会永久保存到数据库中
2.sql标准中定义了四种隔离,较低级别的隔离可以执行更高的并发,开销也更低...READ UNCOMMITTED 未提交读,事务中的修改还没提交,其他事务就可以看到,这也是脏读,一般不会用
READ COMMITED 提交读,大多数的默认级别,在提交之前,所做的任何修改对其他事务都是不可见的...REPEATABLE READ 可重复读,解决了脏读的问题,保证了同一个事务中多次读取同一个记录结果一致,但是还是会有幻读问题
SERIALIZABLE 可串行化,避免幻读问题,每一行都加锁
3.事务的隔离级别下的问题...,也不能读取修改提交的,但是当另一个事务插入新数据提交后,我本次事务有时会插入冲突,或者更新时更新的数据多了
加锁:强制串行执行,锁开销比较大
4.查看隔离级别:
select @@global.tx_isolation