ASP源码.NET源码PHP源码JSP源码JAVA源码DELPHI源码PB源码VC源码VB源码Android源码
当前位置:首页 >> 数据库 >> Oracle >> 源码-PL/SQL从入门到精通-第十一章-事务处理和锁定

源码-PL/SQL从入门到精通-第十一章-事务处理和锁定

来源:网络整理     时间:2016-07-20     关键词:

本篇文章主要介绍了" 源码-PL/SQL从入门到精通-第十一章-事务处理和锁定",主要涉及到方面的内容,对于Oracle感兴趣的同学可以参考一下: 随笔:基本概念早就知道,重点不在于会不会,而在于:会多少?做过什么?怎么做?我的需求你什么时候能实现?...表锁定模式:row share, row exclu...

随笔:

基本概念早就知道,重点不在于会不会,而在于:会多少?做过什么?怎么做?我的需求你什么时候能实现?...

表锁定模式:row share, row exclusive, share lock, share row exclusive, exclusive,暂时不懂,还需继续努力。

--第11章开始
--代码11.1 使用Commit语句提交事务
DECLARE
   dept_no   NUMBER (2) := 31;
BEGIN
   --开始事务
   INSERT INTO dept 
        VALUES (dept_no, '市场部', '北京');             --插入部门记录     
   INSERT INTO emp                                        --插入员工记录
        VALUES (6993, '威尔', '销售', NULL, TRUNC (SYSDATE), 5000,300, dept_no);
   --提交事务
   COMMIT;
END;

select * from dept;
select * from emp;

DELETE FROM emp WHERE deptno=70;
DELETE FROM dept WHERE deptno=70;
COMMIT;

--代码11.2 使用rollback语句回滚事务 (不回滚也没啥事吧?真个PL/SQL是作为一个整体执行的,一部分出错,整体都不执行吧)
DECLARE
   dept_no   NUMBER (2) := 71;
BEGIN
   --开始事务
   INSERT INTO dept 
        VALUES (dept_no, '市场部', '北京');               --插入部门记录
   INSERT INTO dept 
        VALUES (dept_no, '后勤部', '上海');               --插入相同编号的部门记录        
   INSERT INTO emp                                        --插入员工记录
        VALUES (7997, '威尔', '销售人员', NULL, TRUNC (SYSDATE), 5000,300, dept_no);
   --提交事务
   COMMIT;
EXCEPTION
   WHEN DUP_VAL_ON_INDEX THEN                            --捕足异常
     DBMS_OUTPUT.PUT_LINE(SQLERRM);                   --显示异常消息
     ROLLBACK;                                           --回滚异常
END;

--代码11.3 使用保存点局部回滚
DECLARE
   dept_no   NUMBER (2) :=91;
BEGIN
   --开始事务
   SAVEPOINT A;
   INSERT INTO dept 
        VALUES (dept_no, '市场部', '北京');               --插入部门记录
   SAVEPOINT B;   
   INSERT INTO emp                                        --插入员工记录
        VALUES (7997, '威尔', '销售', NULL, TRUNC (SYSDATE), 5000,300, dept_no);        
   SAVEPOINT C;                
   INSERT INTO dept 
        VALUES (dept_no, '后勤部', '上海');               --插入相同编号的部门记录
   --提交事务
   COMMIT;
EXCEPTION
   WHEN DUP_VAL_ON_INDEX THEN                            --捕足异常
     DBMS_OUTPUT.PUT_LINE(SQLERRM);                   --显示异常消息
     ROLLBACK TO B;                                      --回滚异常
END;

SELECT * FROM dept;

DELETE FROM dept WHERE deptno=80;
COMMIT;

--代码11.4 只读事务使用示例
DECLARE
   v_1981 NUMBER(2);
   v_1982 NUMBER(2);
   v_1983 NUMBER(2);
BEGIN
   --SET TRANSACTION必须在事务的第1条语句,因此可以在COMMIT或ROLLBACK后面。
   COMMIT;
   SET TRANSACTION READ ONLY NAME '统计年度入职数据';     --使用NAME为事务命名
   --使用SELECT语句执行查询
   SELECT COUNT(empno) INTO v_1981 FROM emp WHERE TO_CHAR(hiredate,'YYYY')='1981';
   SELECT COUNT(empno) INTO v_1982 FROM emp WHERE TO_CHAR(hiredate,'YYYY')='1982';
   SELECT COUNT(empno) INTO v_1983 FROM emp WHERE TO_CHAR(hiredate,'YYYY')='1983';  
   COMMIT;  --终止只读事务
   DBMS_OUTPUT.PUT_LINE('1981年入职人数:'||v_1981);   --显示统计的结果
   DBMS_OUTPUT.PUT_LINE('1982年入职人数:'||v_1982);
   DBMS_OUTPUT.PUT_LINE('1983年入职人数:'||v_1983);              
END;   

--记录锁定
SELECT * FROM emp WHERE deptno=10 FOR UPDATE;
COMMIT;

--记录锁定(no wait)
SELECT * FROM emp WHERE deptno=10 FOR UPDATE NOWAIT;
COMMIT;

以上就介绍了 源码-PL/SQL从入门到精通-第十一章-事务处理和锁定,包括了方面的内容,希望对Oracle有兴趣的朋友有所帮助。

本文网址链接:http://www.codes51.com/article/detail_2831485.html

相关图片

相关文章