Oracle数据库事务的开启与结束详解


Posted in Oracle onJune 25, 2022

前言

Oracle的事务开始于一个DML语句。

当以下情况发生时,事务结束:

1、COMMIT/ROLLBACK

2、执行了DDL/DCL语句

3、客户端主动断开数据库的连接(DISCONNECT)

4、数据库关闭(宕机)

另外,一个DDL/DCL语句实际上就是一个事务,其中隐含了COMMIT。

Oracle不需要特别的去指定事务的开始和结束。一个事务的结束就是下一个事务的开始。

事务是用来分割数据库活动的逻辑工作单元。事务既有起点,也有终点:当发生下列事件时,事务就开始了:

1.连接到数据库上,并执行第一条DML语句

2.前一个事务结束后,又输入另外一条DML语句

在下列事件之一发生时,事务就结束了:

1.执行Commit或者RollBack语句

2.执行一条DDL语句,例如Create Table语句;在这种情况下,会自动执行Commit语句

3.执行一条DCL语句,例如Grant语句;在这种情况下,会自动执行Commit语句

4.断开与数据库链接。在退出SQLPlus事,通常会输入EXit命令,此时会自动执行Commit语句。如果SQLPlus被意外终止(例如运行SQL*Plus的计算机崩溃)那么就会执行RollBack语句

事务完成后,如果不显式的提交或者回滚事务,都被认为是不好的编程习惯,因此确保在每个事物后面都要执行Commit或者RollBack语句。

事务中任何地方都可以设置一个保存点(savepoint),这样可以将修改回滚到保存点处。

commit

create table  transaction_table8 as select * from dba_objects;
insert into transaction_table8 select * from transaction_table8;

Oracle数据库事务的开启与结束详解

select xid, status from v$transaction;

Oracle数据库事务的开启与结束详解

Truncate – DDL

Oracle数据库事务的开启与结束详解
Oracle数据库事务的开启与结束详解

select xxx for update

select * from transaction_table8 where rownum=1 for update;

Oracle数据库事务的开启与结束详解

Oracle数据库事务的开启与结束详解

select…for update使用方法

作用:

select for update 是为了在查询时,避免其他用户以该表进行插入,修改或删除等操作,造成表的不一致性.

给你举几个例子:

select * from t for update 会等待行锁释放之后,返回查询结果。
select * from t for update nowait 不等待行锁释放,提示锁冲突,不返回结果
select * from t for update wait 5 等待5秒,若行锁仍未释放,则提示锁冲突,不返回结果
select * from t for update skip locked 查询返回查询结果,但忽略有行锁的记录

SELECT...FOR UPDATE 语句的语法如下:

  SELECT ... FOR UPDATE [OF column_list][WAIT n|NOWAIT][SKIP LOCKED];

其中:

  OF 子句用于指定即将更新的列,即锁定行上的特定列。

  WAIT 子句指定等待其他用户释放锁的秒数,防止无限期的等待。

“使用FOR UPDATE WAIT”子句的优点如下:

  1防止无限期地等待被锁定的行;

  2允许应用程序中对锁的等待时间进行更多的控制。

  3对于交互式应用程序非常有用,因为这些用户不能等待不确定

  4 若使用了skip locked,则可以越过锁定的行,不会报告由wait n 引发的‘资源忙’异常报告

补充几点:

分成两类:加锁范围子句和加锁行为子句

加锁范围子句:在select…for update之后,可以使用of子句选择对select的特定数据表进行加锁操作。默认情况下,不使用of子句表示在select所有的数据表中加锁

加锁行为子句:当我们进行for update的操作时,与普通select存在很大不同。一般select是不需要考虑数据是否被锁定,最多根据多版本一致读的特性读取之前的版本。加入for update之后,Oracle就要求启动一个新事务,尝试对数据进行加锁。如果当前已经被加锁,默认的行为必然是block等待。使用nowait子句的作用就是避免进行等待,当发现请求加锁资源被锁定未释放的时候,直接报错返回。

在日常中,我们对for update的使用还是比较普遍的,特别是在如pl/sql developer中手工修改数据。此时只是觉得方便,而对for update真正的含义缺乏理解。

For update是Oracle提供的手工提高锁级别和范围的特例语句。Oracle的锁机制是目前各类型数据库锁机制中比较优秀的。所以,Oracle认为一般不需要用户和应用直接进行锁的控制和提升。甚至认为死锁这类锁相关问题的出现场景,大都与手工提升锁有关。

所以,Oracle并不推荐使用for update作为日常开发使用。而且,在平时开发和运维中,使用了for update却忘记提交,会引起很多锁表故障。 那么,什么时候需要使用for update?就是那些需要业务层面数据独占时,可以考虑使用for update。场景上,比如火车票订票,在屏幕上显示邮票,而真正进行出票时,需要重新确定一下这个数据没有被其他客户端修改。所以,在这个确认过程中,可以使用for update。这是统一的解决方案方案问题,需要前期有所准备。

失败的DML 和 exit

Oracle数据库事务的开启与结束详解

Oracle数据库事务的开启与结束详解

DCL

Oracle数据库事务的开启与结束详解

Oracle数据库事务的开启与结束详解

Oracle数据库事务的开启与结束详解

总结 

到此这篇关于Oracle数据库事务的开启与结束的文章就介绍到这了,更多相关Oracle事务开启与结束内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!


Tags in this post...

Oracle 相关文章推荐
Oracle 数据仓库ETL技术之多表插入语句的示例详解
Apr 12 Oracle
Oracle11g R2 安装教程完整版
Jun 04 Oracle
Oracle创建只读账号的详细步骤
Jun 07 Oracle
SQL模糊查询报:ORA-00909:参数个数无效问题的解决
Jun 21 Oracle
RPM包方式安装Oracle21c的方法详解
Aug 23 Oracle
C#连接ORACLE出现乱码问题的解决方法
Oct 05 Oracle
在Oracle表中进行关键词搜索的过程
Jun 10 Oracle
Oracle 11g数据库使用expdp每周进行数据备份并上传到备份服务器
Jun 28 Oracle
ORACLE中dbms_output.put_line输出问题的解决过程
Jun 28 Oracle
Oracle查看表空间使用率以及爆满解决方案详解
Jul 23 Oracle
在Oracle表中进行关键词搜索的过程
Jun 10 #Oracle
Oracle锁表解决方法的详细记录
Jun 05 #Oracle
oracle数据库去除重复数据
May 20 #Oracle
解决Oracle数据库用户密码过期
May 11 #Oracle
Oracle中DBLink的详细介绍
instantclient客户端 连接oracle数据库
清空 Oracle 安装记录并重新安装
You might like
PHP的魔术常量__METHOD__简介
2014/07/08 PHP
php生成二维码时出现中文乱码的解决方法
2014/12/18 PHP
php选择排序法实现数组排序实例分析
2015/02/16 PHP
php显示时间常用方法小结
2015/06/05 PHP
Yii 框架使用数据库(databases)的方法示例
2020/05/19 PHP
JS的IE和Firefox兼容性集锦
2006/12/11 Javascript
js使用函数绑定技术改变事件处理程序的作用域
2011/12/26 Javascript
基于jquery自定义图片热区效果
2012/07/21 Javascript
JavaScript中的包装对象介绍
2015/01/27 Javascript
基于jQuery Circlr插件实现产品图片360度旋转
2015/09/20 Javascript
js鼠标单击和双击事件冲突问题的快速解决方法
2016/07/11 Javascript
AngularJS实现页面定时刷新
2017/03/14 Javascript
JS去掉字符串前后空格或去掉所有空格的用法
2017/03/25 Javascript
分分钟学会vue中vuex的应用(入门教程)
2017/09/14 Javascript
js将键值对字符串转为json字符串的方法
2018/03/30 Javascript
小程序实现带年月选取效果的日历
2018/06/27 Javascript
vue表单自定义校验规则介绍
2018/08/28 Javascript
Json实现传值到后台代码实例
2020/06/30 Javascript
原生JS实现多条件筛选
2020/08/19 Javascript
[01:15:45]DOTA2上海特级锦标赛B组小组赛#1 Alliance VS Spirit第一局
2016/02/26 DOTA
python队列通信:rabbitMQ的使用(实例讲解)
2017/12/22 Python
python实现简易云音乐播放器
2018/01/04 Python
python实现冒泡排序算法的两种方法
2018/03/10 Python
Python面向对象程序设计多继承和多态用法示例
2019/04/08 Python
django项目用higcharts统计最近七天文章点击量
2019/08/17 Python
Python高级特性——详解多维数组切片(Slice)
2019/11/26 Python
Python进行统计建模
2020/08/10 Python
Python3+SQLAlchemy+Sqlite3实现ORM教程
2021/02/16 Python
亚洲最大的眼镜批发商和零售商之一:Glasseslit
2018/10/08 全球购物
学习党代会心得体会
2014/09/05 职场文书
企业战略合作意向书
2015/05/08 职场文书
2015年信息宣传工作总结
2015/05/26 职场文书
欠条范文
2015/07/03 职场文书
师德师风培训感言
2015/08/03 职场文书
2016会计专业自荐信范文
2016/01/28 职场文书
windows系统安装配置nginx环境
2022/06/28 Servers