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

随笔:

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

表锁定模式: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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值