加入收藏 | 设为首页 | 会员中心 | 我要投稿 焦作站长网 (https://www.0391zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长资讯 > 外闻 > 正文

mysql oracle默认事务隔离级别的讲解

发布时间:2021-10-12 17:45:03 所属栏目:外闻 来源:互联网
导读:这篇文章主要介绍了mysql、oracle默认事务隔离级别的说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧 1.事务的特性(ACID) (1)原子性

这篇文章主要介绍了mysql、oracle默认事务隔离级别的说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

 

1.事务的特性(ACID)

 

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

 

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

 

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

 

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

 

2.事务隔离级别

 

(1)read uncommitted 未提交读

 

所有事务都可以看到没有提交事务的数据。

 

(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

mysql oracle默认事务隔离级别的讲解

(编辑:焦作站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读