查询数据库事务隔离级别
2016-05-30 11:21
211 查看
MySQL
1.查看当前会话隔离级别
select @@tx_isolation;
2.查看系统当前隔离级别
select @@global.tx_isolation;
3.设置当前会话隔离级别
set session transaction isolatin level repeatable read;
4.设置系统当前隔离级别
set global transaction isolation level repeatable read;
5.命令行,开始事务时
set autocommit=off 或者 start transaction
关于隔离级别的理解
1.read uncommitted
可以看到未提交的数据(脏读),举个例子:别人说的话你都相信了,但是可能他只是说说,并不实际做。
2.read committed
读取提交的数据。但是,可能多次读取的数据结果不一致(不可重复读,幻读)。用读写的观点就是:读取的行数据,可以写。
3.repeatable read(MySQL默认隔离级别)
可以重复读取,但有幻读。读写观点:读取的数据行不可写,但是可以往表中新增数据。在MySQL中,其他事务新增的数据,看不到,不会产生幻读。采用多版本并发控制(MVCC)机制解决幻读问题。
4.serializable
可读,不可写。像java中的锁,写数据必须等待另一个事务结束。
相关文章推荐
- 数据库事务隔离级别
- 数据库事务隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 数据库事务隔离级别
- 事务、数据库事务、事务隔离级别、锁的简单总结
- 数据库事务隔离级别
- 数据库事务隔离级别<转>
- 初识-数据库事务隔离级别
- 数据库中事务的四大特性(ACID) and 事务的隔离级别。
- 数据库事务隔离级别总结
- 数据库事务的四大特性以及事务的隔离级别
- 数据库中事务的隔离级别 小结
- 数据库事务的隔离级别 (转)
- 数据库事务隔离级别
- 数据库事务中的隔离级别和锁+spring Transactional注解
- 数据库事务隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- Hibernate 数据库事务与隔离级别
- 数据库事务4种隔离级别及7种传播行为
- 数据库事务隔离级别-- 脏读、幻读、不可重复读(清晰解释)