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;
Mos固件,小电视必刷固件
ES6 教程
Vue.js 教程
JSON 教程
jQuery 教程
HTML 教程
HTML 5 教程
CSS 教程
CSS3 教程
JavaScript 教程
DHTML 教程
JSON在线格式化工具
JS在线运行
JSON解析格式化
jsfiddle中国国内版本
JS代码在线运行
PHP代码在线运行
Java代码在线运行
C语言代码在线运行
C++代码在线运行
Python代码在线运行
Go语言代码在线运行
C#代码在线运行
JSRUN闪电教程系统是国内最先开创的教程维护系统, 所有工程师都可以参与共同维护的闪电教程,让知识的积累变得统一完整、自成体系。
大家可以一起参与进共编,让零散的知识点帮助更多的人。
X

选择支付方式:


立即支付

¥
9.99
无法付款,请点击这里
金额: 0 元
备注:
转账时请填写正确的金额和备注信息,到账由人工处理,可能需要较长时间
备注:
转账时请填写正确的金额和备注信息,到账由人工处理,可能需要较长时间
如有疑问请联系QQ:565830900
正在生成二维码, 此过程可能需要15秒钟