ORACLE 之 事务(ONE)
2013-04-02 21:08
134 查看
oracle 之 事务(one)
一)事务处理过程1、首先客户端要连接到服务器,服务器会分配相关进程来回应用户请求操作。
2、服务器开始接收用户的sql操作,那么首先检查share pool,查看是否有包含该sql语句的共享sql区,如果有,那么会检查用户对所要操作的对象是否有相关权限,如果有那么sql共享区会处理该sql语句。如果没有sql共享区,那么会分配一个新的sql共享区,以便分析和处理sql语句。如果用户对所要操作的对象没有权限,则会提示报错出现无权限提示。
3、锁定该sql语句所要操作的对象
4、服务器进程处理sga中的数据,如果数据没有在sga中,那么将从数据文件中读取到sga的buffer cache中进行处理。
5、在适当的时刻,lgwr进程会把redo log buffer 中的重做日志条目写入到联机日志中,同样,dbwr后台写入进程也会把相应的buffer cache 中的数据写入到数据文件中。
6、为该事物分配一个scn,该scn可以保证数据的一致性,用于并发控制和数据库的恢复。该scn会被记录到控制文件、数据文件头部、数据块头部以及重做日志中。
7、lgwr后台进程会把所有的剩余的、已经缓冲的重做日志和scn写入到联机日志中去(改过程可以理解为commit和rollback),一旦写入成功,那么这个事务就被记录完成了,这次事务的操作结果都被永久的记录下来了,如果后续突然发生故障,那么也可以应用该日志进行事务的操作变更恢复数据。
8、事务处理完成后,那么服务器会释放sql语句所占用的资源,并解除对操作对象的锁定操作。
9、当事务是(提交事务或是回滚事务)成功就会提示相关成功操作内容。否则提示错误
10、在适当的时刻,dbwr进程会把缓冲区中剩余的脏块全部写入到数据文件中。
二)事务控制语句及功能
1) 事务控制语句有:
commit; 提交事务
rollback;回滚事务
savepoint 设置部分事务的保存点
rollback savepoint ;回退到事务的保存点(事务还是没有完成)
set transaction;设置事务的属性
set constraints ;设置可以延迟约束的检查机制
2)事务的开始与结束
事务没有明确的开始,连接到了数据库并执行一条sql语句那么就开始了事务。
在发生如下情况的时候事务就结束了;
执行commit或rollback语句完后,那么事务就结束了,但rollback savepoint是回到一部分事务时刻这个时候事务还是没有结束的。
在执行dml语句失败的时候,事务就自动结束了。
在设置了一条会自动提交的语句的时候,事务就结束了
在一下情况事务会自动提交
在进行ddl操作的时候,事务会自动提交
设置 set autocommit on之后每次执行完dml语句,数据库都会自己提交事务。
当disconnect数据库后,事务会自动回滚rollback,事务也就结束了。
3)提交事务情况和回退全部事务情况
4)设置事务保存点,回退部分事务
测试如下:
SCOTT@orcl#select * from emp; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- -------------------- ------------------ ---------- -------------- ---------- ---------- ---------- 7369 SMITH CLERK 7902 17-12月-80 800 20 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7788 SCOTT ANALYST 7566 19-4月 -87 4000 20 7839 KING PRESIDENT 17-11月-81 5000 10 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7876 ADAMS CLERK 7788 23-5月 -87 1100 20 EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- -------------------- ------------------ ---------- -------------- ---------- ---------- ---------- 7900 JAMES CLERK 7698 03-12月-81 950 30 7902 FORD ANALYST 7566 03-12月-81 3000 20 7000 MILLER CLERK 9000 23-1月 -82 2000 10 已选择14行。 SCOTT@orcl#update emp set mgr=2000 where empno=7000; 已更新 1 行。 SCOTT@orcl#select * from emp; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- -------------------- ------------------ ---------- -------------- ---------- ---------- ---------- 7369 SMITH CLERK 7902 17-12月-80 800 20 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7788 SCOTT ANALYST 7566 19-4月 -87 4000 20 7839 KING PRESIDENT 17-11月-81 5000 10 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7876 ADAMS CLERK 7788 23-5月 -87 1100 20 EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- -------------------- ------------------ ---------- -------------- ---------- ---------- ---------- 7900 JAMES CLERK 7698 03-12月-81 950 30 7902 FORD ANALYST 7566 03-12月-81 3000 20 7000 MILLER CLERK 2000 23-1月 -82 2000 10 已选择14行。 SCOTT@orcl#savepoint sp1 2 ;
SCOTT@orcl#rollback to sp1; 回退已完成。 SCOTT@orcl#select * from emp; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- -------------------- ------------------ ---------- -------------- ---------- ---------- ---------- 7369 SMITH CLERK 7902 17-12月-80 800 20 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7788 SCOTT ANALYST 7566 19-4月 -87 4000 20 7839 KING PRESIDENT 17-11月-81 5000 10 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7876 ADAMS CLERK 7788 23-5月 -87 1100 20 EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- -------------------- ------------------ ---------- -------------- ---------- ---------- ---------- 7900 JAMES CLERK 7698 03-12月-81 950 30 7902 FORD ANALYST 7566 03-12月-81 3000 20 7000 MILLER CLERK 2000 23-1月 -82 2000 10 已选择14行。 SCOTT@orcl#exit 从 Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - 64bit Production With the Partitioning, OLAP, Data Mining and Real Application Testing options 断开 oracle@oracle:~/test> sqlplus "/as sysdba" SQL*Plus: Release 11.1.0.6.0 - Production on 星期二 4月 2 22:51:52 2013 Copyright (c) 1982, 2007, Oracle. All rights reserved. 连接到: Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - 64bit Production With the Partitioning, OLAP, Data Mining and Real Application Testing options SYS@orcl#conn scott/root 已连接。 SCOTT@orcl#select * from emp; EMPNO ENAME JOB MGR HIREDATE ---------- -------------------- ------------------ ---------- -------------- SAL COMM DEPTNO ---------- ---------- ---------- 7369 SMITH CLERK 7902 17-12月-80 800 20 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 EMPNO ENAME JOB MGR HIREDATE ---------- -------------------- ------------------ ---------- -------------- SAL COMM DEPTNO ---------- ---------- ---------- 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 EMPNO ENAME JOB MGR HIREDATE ---------- -------------------- ------------------ ---------- -------------- SAL COMM DEPTNO ---------- ---------- ---------- 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7788 SCOTT ANALYST 7566 19-4月 -87 4000 20 7839 KING PRESIDENT 17-11月-81 5000 10 EMPNO ENAME JOB MGR HIREDATE ---------- -------------------- ------------------ ---------- -------------- SAL COMM DEPTNO ---------- ---------- ---------- 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7876 ADAMS CLERK 7788 23-5月 -87 1100 20 7900 JAMES CLERK 7698 03-12月-81 950 30 EMPNO ENAME JOB MGR HIREDATE ---------- -------------------- ------------------ ---------- -------------- SAL COMM DEPTNO ---------- ---------- ---------- 7902 FORD ANALYST 7566 03-12月-81 3000 20 7000 MILLER CLERK 2000 23-1月 -82 2000 10 已选择14行。 SCOTT@orcl#show autocommit; autocommit OFF SCOTT@orcl#
注意:rollback to savepoint 不会结束本次事务。
相关文章推荐
- Oracle 起步日记(9)——事务与并发控制
- 对ORACLE 已提交的事务进行回滚之详细版和操作版
- oracle中事务处理
- Copy Records From One Data Block To Another Data Block In Oracle Forms
- oracle 学习笔记(十) 事务控制语句
- 十、Oracle数据库之学习笔记---Oracle事务处理
- [置顶] Oracle GoldenGate 常见问题:长事务处理
- oracle 事务 相关
- 【Oracle】5.事务
- Oracle 触发器 自治事务
- Oracle 事务
- 【Oracle 11g】梳理下和事务相关的一些概念
- Oracle12C--Oracle事务处理(十一)
- mssql,firebird,oracle对事务的处理不同
- [转]oracle中使用set transaction设置事务属性
- oracle事务特性详解
- Oracle 11g 学习五:子查询,数据更新操作,事务处理和数据伪列
- oracle 的自治事务
- oracle教程之DML事务锁定的机制
- oracle中的事务