源码-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;
基本概念早就知道,重点不在于会不会,而在于:会多少?做过什么?怎么做?我的需求你什么时候能实现?...
表锁定模式: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;
相关文章推荐
- 【mysql】执行mysql脚本
- MAC下安装MySQL以及重置初始密码详细教程
- Oracle11g 配置 ST_GEOMETRY
- SQL 生产随时唯一32位字符串
- DB2使用命令行连接远程数据库(DB2客户端工具使用教程)
- mysql,实现数据库检索结果添加自增的序号
- ubuntu系统中解决mysql乱码
- 转:Oracle R12 多组织访问的控制 - MOAC(Multi-Org Access Control)
- memcached 最佳实践
- ORA-15027: active use of diskgroup "TEST" precludes its dismount
- Sql日期时间格式转换大全
- mysql给root开启远程访问权限,修改root密码
- sql中 datediff的使用
- Sql server DATEADD日期函数的使用
- sql server 数值的四舍五入
- sql中常见日期获取
- mysql服务一些问题
- 在SQL Server中用好模糊查询指令LIKE
- Mongodb启动命令mongod参数说明
- pl/sql left join子句注意事项