您的位置:首页 > 数据库

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

2016-07-20 16:52 501 查看
随笔:

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

表锁定模式: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;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: