mysql、oracle默认事务隔离级别

1.事务的特性(ACID)mysql

(1)原子性(Atomicity)。事务中所涉及的程序对数据库的修改操做要么所有成功,要么所有失败。sql

(2)一致性(Consistency)。事务执行前和执行后来源和去向保持平衡。数据库

(3)隔离性(Isolation)。并发时每一个事务是隔离的,相互不影响。session

(4)持久性(Durubility)。一旦事务成功提交,应该保证数据的完整存在。并发

2.事务隔离级别oracle

(1)read uncommitted 未提交读.net

全部事务均可以看到没有提交事务的数据。blog

(2)read committed 提交读排序

事务成功提交后才能够被查询到。事务

(3)repeatable 重复读

同一个事务多个实例读取数据时,可能将未提交的记录查询出来,而出现幻读。mysql默认级别

(4)Serializable可串行化

强制的进行排序,在每一个读读数据行上添加共享锁。会致使大量超时现象和锁竞争。


MySQL

mysql默认的事务处理级别是'REPEATABLE-READ',也就是可重复读

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;

Oracle

oracle数据库支持READ COMMITTED 和 SERIALIZABLE这两种事务隔离级别。

默认系统事务隔离级别是READ COMMITTED,也就是读已提交

1.查看系统默认事务隔离级别,也是当前会话隔离级别

--首先建立一个事务
declare
     trans_id Varchar2(100);
  begin
     trans_id := dbms_transaction.local_transaction_id( TRUE );
  end; 
--查看事务隔离级别

SELECT s.sid, s.serial#,

  CASE BITAND(t.flag, POWER(2, 28))     WHEN 0 THEN 'READ COMMITTED'     ELSE 'SERIALIZABLE'   END AS isolation_level FROM v$transaction t JOIN v$session s ON t.addr = s.taddr AND s.sid = sys_context('USERENV', 'SID'); ---------------------  做者:剑海风云  来源:CSDN  原文:https://blog.csdn.net/nanxiaotao/article/details/80412196  版权声明:本文为博主原创文章,转载请附上博文连接!

相关文章
相关标签/搜索