JSRUN 用代码说话

SET TRANSACTION语句(设置事务)

编辑教程

SET TRANSACTION语句(设置事务)

在 Oracle 中,SET TRANSACTION 语句可以用来设置事务的各种状态,比如只读、读/写、隔离级别,为事务分配名称或将事务分配回滚段等等。

SET TRANSACTION语法

Oracle中SET TRANSACTION语句的语法是:

SET TRANSACTION [ READ ONLY | READ WRITE ]
                [ ISOLATION LEVEL [ SERIALIZE | READ COMMITED ]
                [ USE ROLLBACK SEGMENT 'segment_name' ]
                [ NAME 'transaction_name' ];

参考

READ ONLY 可以将事务设置为只读事务。
READ WRITE 可以将事务设置为读/写事务。
ISOLATION LEVEL 如果指定,它有两个选项:
ISOLATION LEVEL SERIALIZE:
如果事务尝试更新由另一个事务更新并未提交的资源,则事务将失败。

ISOLATION LEVEL READ COMMITTED:
如果事务需要另一个事务持有的行锁,则事务将等待,直到行锁被释放。
USE ROLLBACK SEGMENT 可选的。 如果指定,它将事务分配给由 'segment_name' 标识的回退段,该段是用引号括起来的段名称。
NAME 为 'transaction_name' 标识的事务分配一个名称,该事务用引号括起来。

SET TRANSACTION 示例

下面我们来看一个演示如何在 Oracle 中使用 SET TRANSACTION 语句的示例。

只读

首先,下面来看看看如何使用SET TRANSACTION语句将事务设置为只读。

SET TRANSACTION READ ONLY NAME 'RO_example';

此示例会将事务设置为只读,并为其分配“RO_example”的名称。

读写

下面是如何使用 SET TRANSACTION 语句将事务设置为读/写的示例:

SET TRANSACTION READ WRITE NAME 'RW_example';

use rollback segment 实例

一般在做报表查询的时候,可以先设置该查询事务为一个只读事务,以避免出现写操作。

DECLARE
  l_name VARCHAR2(100);
  l_age  NUMBER;
  l_sex  VARCHAR2(2);
BEGIN
  -- 为保证set transaction是事务的第一条语句,先使用commit或rollback来结束掉前面可能存在的事务
  COMMIT;
  -- 使用name给事务命名
  SET TRANSACTION READ ONLY NAME '查询报表';
  SELECT NAME
    INTO l_name
    FROM student
   WHERE student_id = 1001;
  SELECT age
    INTO l_age
    FROM student
   WHERE student_id = 1001;
  SELECT sex
    INTO l_sex
    FROM student
   WHERE student_id = 1001;
  -- 终止只读事务
  COMMIT;
  dbms_output.put_line('输出:' || l_name || l_age || l_sex);
END;
JSRUN闪电教程系统是国内最先开创的教程维护系统, 所有工程师都可以参与共同维护的闪电教程,让知识的积累变得统一完整、自成体系。 大家可以一起参与进共编,让零散的知识点帮助更多的人。
X
支付宝
9.99
无法付款,请点击这里
金额: 0
备注:
转账时请填写正确的金额和备注信息,到账由人工处理,可能需要较长时间
如有疑问请联系QQ:565830900
正在生成二维码, 此过程可能需要15秒钟