Oracle 事务的开启和结束

本文详细介绍了Oracle数据库中事务的开始与结束条件,包括DML语句触发、COMMIT/ROLLBACK操作、DDL/DCL语句的影响以及客户端断开连接的情况。强调了DDL/DCL语句隐含COMMIT,并提醒在事务结束后进行显式提交或回滚的重要性。此外,还提到了保存点的使用以及事务中涉及的关键SQL语句,如SELECT...FOR UPDATE。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Oracle 事务的开启和结束

1

Oracle的事务开始于一个DML语句。
当以下情况发生时,事务结束:
1、COMMIT/ROLLBACK
2、执行了DDL/DCL语句
3、客户端主动断开数据库的连接(DISCONNECT)
4、数据库关闭(宕机)
另外,一个DDL/DCL语句实际上就是一个事务,其中隐含了COMMIT。
Oracle不需要特别的去指定事务的开始和结束。一个事务的结束就是下一个事务的开始。

2

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

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;

在这里插入图片描述

select xid, status from v$transaction;

在这里插入图片描述

Truncate – DDL

在这里插入图片描述
在这里插入图片描述

select xxx for update

select * from transaction_table8 where rownum=1 for update;

在这里插入图片描述

在这里插入图片描述

select…for update使用方法

失败的DML 和 exit

在这里插入图片描述
在这里插入图片描述

DCL

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值