orcale 事务管理

数据库事务:保证一组sql执行的结果作为一个整体永久性的修改数据库的内容,或作为一个整体取消对数据库的修改。

事务的开始于DML语句(INSERT UPDATE DELETE)
事务的结束于COMMIT或ROLLBACK语句。
执行一条DML语句,该语句失败了,会为这个无效的DML语句执行rollback;
执行一条DDL语句,如create table会自动执行commit;
执行一条DCL语句,如grant 语句会自动执行commit;
sqlplus 在exit退出时,会自动执行commit,sqlplus被意外终止时会自动执行rollback.Java程序访问数据库时,如果程序意外崩溃,也会自动执行rollback;

保存点  
创建: savepoint save1;
执行: rollback to savepoint save1;

ACID特性:
原子性(Atomic):事务时原子的,一个事务中包含的所有Sql语句都是一个不可分割的工作单元。
一致性(Consist):事务必须确保数据库的状态保持一致,就是事务开始时,结束时数据库的状态必须保持一致。、
隔离性(Isolated):多个事务可以独立运行,而彼此互不影响
持久性(Durable):事务一旦提交,数据库变化会永久性保存下来。

事务并发(concurrent transation):多用户同时执行自己的事务

读不阻塞读,写不阻塞读,在对相同行进行写时,才会阻塞写。

事务隔离级别 transation isolation level 是一个事务对数据库的修改与并行的另外一个事务的隔离程度。

幻读 phantom read: 事务TA 按一定条件查询,随后事务TB新插入一提记录,且这条记录满足TA的查询条件,TA再次查询时会检索到TB刚刚插入的行,这个新记录就称为幻像。

不可重复读 nonrepeatable read 事务TA读取一条记录,随后TB修改了TTA刚读取的那一行记录,TA再次读取这一条记录时,发现与刚才读取的记录已经发生了变化。、

脏读 dirty read 事务TA更新了一行的内容,但是并没有提交,事务TB 读取更新后的行,然后TA执行回滚操作,现在TB所读取的行就无效了,也称脏数据。

SQL 标准定义了以下四种事务隔离级别 按隔离性级别从低到高依次为:

READ UNCOMMITTED   允许 幻读 不可重复读 脏读
READ COMMITTED     允许 幻读 不可重复读
REPEATABLE READ    允许 幻读
SERIALIZABLE       均不允许

orcale数据库支持热read committed和serializable两种隔离级别,默认是 read commited。orcale不支持read uncommitted、repeatable read.

隔离级别的设置:
set transation isolation level serializable;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值