MYSQL隔离级别介绍
2015-08-11 19:39
525 查看
转自:http://blog.csdn.net/joe_007/article/details/7014381
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中的锁,写数据必须等待另一个事务结束。
关于隔离级别的理解参考了andyhu1007的文章:http://www.iteye.com/topic/322382
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中的锁,写数据必须等待另一个事务结束。
关于隔离级别的理解参考了andyhu1007的文章:http://www.iteye.com/topic/322382
相关文章推荐
- what-to-tune-in-mysql-56-after-installation.html
- Mysql全文本检索-MyISM引擎,Where子句中使用Match() Against()-布尔模式
- 数据库MySQL操作
- mysql中如何复制一行数据
- 修改mysql的默认存储引擎为InnoDB
- 通过saltstack源码安装mysql
- MySQL必知必会笔记(六)插入数据 创建和操纵表
- mysql主从灾备
- mysql当中时间类型是如何存储的
- Mysql组合查询-UNION-多个SELECT语句作为单个查询结果返回
- mysql备份
- mysql 不能登录
- JDBC+MySql 1(编码问题的处理)
- 利用Navicat传输MySql中不同数据库的数据
- 初步了解MySQL 数据库
- MySQL数据库性能优化专题
- mysql主从复制
- mysql 存储过程中sum 结果赋值给变量的坑
- MySQL Study之--Percona Server版本
- MySQL支持的列类型