1.查看当前会话隔离级别 java
select @@tx_isolation; session
2.查看系统当前隔离级别 并发
select @@global.tx_isolation; 命令行
3.设置当前会话隔离级别 事务
set session transaction isolatin level repeatable read; it
4.设置系统当前隔离级别 io
set global transaction isolation level repeatable read; table
5.命令行,开始事务时 select
set autocommit=off 或者 start transaction 数据
关于隔离级别的理解
1.read uncommitted
能够看到未提交的数据(脏读),举个例子:别人说的话你都相信了,可是可能他只是说说,并不实际作。
2.read committed
读取提交的数据。可是,可能屡次读取的数据结果不一致(不可重复读,幻读)。用读写的观点就是:读取的行数据,能够写。
3.repeatable read(MySQL默认隔离级别)
能够重复读取,但有幻读。读写观点:读取的数据行不可写,可是能够往表中新增数据。在MySQL中,其余事务新增的数据,看不到,不会产生幻读。采用多版本并发控制(MVCC)机制解决幻读问题。
4.serializable
可读,不可写。像java中的锁,写数据必须等待另外一个事务结束。
关于隔离级别的理解参考了andyhu1007的文章:http://www.iteye.com/topic/322382