oracle事务特性详解
原子性
事务是一个完整的操作。事务的各步操作是不可分的(原子的);要么都执行,要么都不执行。
-- 创建表
create table account_money
(
id number(4) not null,
name varchar2(4) not null,
money number(5,2) not null
)
;
-- 增加一个检查约束
alter table account_money
add constraint CK_money
check (money>=0);
--向张三这个账号增加数据
insert into ACCOUNT_MONEY (ID, NAME, MONEY)
values (1001, '张三', 500.00);
insert into ACCOUNT_MONEY (ID, NAME, MONEY)
values (1002, '张三', 1.00);
增加后的表如下:
ID NAME MONEY
1 1001 张三 500.00
2 1002 张三 1.00
以下为oracle事务处理
BEGIN
--从张三的1001账户转入张三的1002账户
UPDATE account_money a SET a.Money=a.Money-600 WHERE a.Id='1001';
UPDATE account_money a SET a.Money=a.Money+600 WHERE a.Id='1002';
COMMIT;--提交事务
EXCEPTION --异常处理
WHEN OTHERS THEN ROLLBACK;--出现异常就回滚
Dbms_Output.Put_Line('转账异常,转账失败');
在上述代码中,因为账户设置了检查约束,当账户小于0时,就会出现异常,如果不进行事务异常处理,那么第二条更新语句会被执行。当做了事务异常处理后,当出现异常就会回滚。
一致性
在事务操作前后,数据必须处于一致状态。是一个业务规则约束的范畴。
同样使用以上的表来做以说明:
DECLARE
account_a account_money.Money%TYPE;
account_b account_money.Money%TYPE;
BEGIN
SELECT a.money INTO account_a FROM account_money a WHERE a.Id='1001';
SELECT a.money INTO account_b FROM account_money a WHERE a.Id='1002';
Dbms_Output.Put_Line('转账前A账户余额:'||account_a);
Dbms_Output.Put_Line('转账前B账户余额:'||account_b);
Dbms_Output.Put_Line('转账前总余额:'||(account_a+account_b));
UPDATE account_money SET money=money-100 WHERE ID='1001';
UPDATE account_money SET money=money+100 WHERE ID='1002';
COMMIT;
SELECT a.money INTO account_a FROM account_money a WHERE a.Id='1001';
SELECT a.money INTO account_b FROM account_money a WHERE a.Id='1002';
Dbms_Output.Put_Line('转账后A账户余额:'||account_a);
Dbms_Output.Put_Line('转账后B账户余额:'||account_b);
Dbms_Output.Put_Line('转账后总余额:'||(account_a+account_b));
EXCEPTION
WHEN OTHERS THEN
Dbms_Output.Put_Line('转账失败,业务取消');
SELECT a.money INTO account_a FROM account_money a WHERE a.Id='1001';
SELECT a.money INTO account_b FROM account_money a WHERE a.Id='1002';
Dbms_Output.Put_Line('停止转账后A账户余额:'||account_a);
Dbms_Output.Put_Line('停止转账后B账户余额:'||account_b);
Dbms_Output.Put_Line('停止转账后总余额:'||(account_a+account_b));
END;
执行上段代码,
执行第一遍:
转账前A账户余额:500
转账前B账户余额:1
转账前总余额:501
转账后A账户余额:400
转账后B账户余额:101
转账后总余额:501
执行第二遍:
转账前A账户余额:400
转账前B账户余额:101
转账前总余额:501
转账后A账户余额:300
转账后B账户余额:201
转账后总余额:501
执行第三遍:
转账前A账户余额:300
转账前B账户余额:201
转账前总余额:501
转账后A账户余额:200
转账后B账户余额:301
转账后总余额:501
。。。。。。
当执行第5遍时:A账户的余额为0,如果再执行会出现象呢?
转账前A账户余额:100
转账前B账户余额:401
转账前总余额:501
转账后A账户余额:0
转账后B账户余额:501
转账后总余额:501
执行第6遍,第7遍…………:
转账前A账户余额:0
转账前B账户余额:501
转账前总余额:501
转账失败,业务取消
停止转账后A账户余额:0
停止转账后B账户余额:501
停止转账后总余额:501
我们会发现,当我们做事务处理后,总额不会发生变化,当出现异常就不会再执行(或者说回滚)!
隔离性
对数据进行修改的所有并发事务是彼此隔离的,这表明事务必须是独立的,它不是以任何方式依赖于或影响其它事务。
每个事务是独立的,我们在PL/SQL中新建两个SQL窗口就以可以做两个事务处理。
我们还是使用以上表,表内容如下:
ID NAME MONEY
1 1001 张三 0.00
2 1002 张三 501.00
第一个SQL窗口:
第二个SQL窗口:
输入:SELECT * FROM account_money;这条查询语句,我们会发现,第一个SQL窗口没有执行之前的数据。
如果我们也在第二个SQL窗口使用update更新数据会怎么样呢?
UPDATE account_money SET money=money+300 WHERE ID='1001';
SELECT * FROM account_money;
他会等待第一个SQL窗口提交事务才会有更新结果!
这时我们提交第一个SQL窗口的事务,我们会看到,两个窗口的结果都发生变化。
我们再提交第二个SQL窗口的事务(在第一个SQL窗口事务没有提交之前是不能提交第二个窗口的事务的),结果也同上图!
持久性
事务完成后,它对数据库的修改被永久保存下来。
oracle事务特性详解的更多相关文章
- (转)Spring事务管理详解
背景:之前一直在学习数据库中的相关事务,而忽略了spring中的事务配置,在阿里面试时候基本是惨败,这里做一个总结. 可能是最漂亮的Spring事务管理详解 https://github.com/Sn ...
- 可能是最漂亮的Spring事务管理详解
Java面试通关手册(Java学习指南):https://github.com/Snailclimb/Java_Guide 微信阅读地址链接:可能是最漂亮的Spring事务管理详解 事务概念回顾 什么 ...
- 可能是最漂亮的Spring事务管理详解 专题
微信阅读地址链接:可能是最漂亮的Spring事务管理详解 事务概念回顾 什么是事务? 事务是逻辑上的一组操作,要么都执行,要么都不执行. 事物的特性(ACID): 原子性: 事务是最小的执行单位,不允 ...
- 最漂亮的Spring事务管理详解
SnailClimb 2018年05月21日阅读 7245 可能是最漂亮的Spring事务管理详解 Java面试通关手册(Java学习指南):github.com/Snailclimb/- 微信阅读地 ...
- oracle表分区详解
原文来自:http://www.cnblogs.com/leiOOlei/archive/2012/06/08/2541306.html oracle表分区详解 从以下几个方面来整理关于分区表的概念及 ...
- Oracle权限管理详解
Oracle权限管理详解 转载--CzmMiao的博客生活 Oracle 权限 权限允许用户访问属于其它用户的对象或执行程序,ORACLE系统提供三种权限:Object 对象级.System 系统级. ...
- Java从入门到精通——数据库篇Oracle 11g服务详解
装上Oracle之后大家都会感觉到我们的电脑慢了下来,如何提高计算机的速度呢?我们应该打开必要的服务,关闭没有用的服务.下面是Oracle服务的详解: Oracle ORCL VSS Writer S ...
- oracle rac IP详解
rac环境下vip/public/private IP的区别 每个节点要2块网卡, 3个IP,虚拟IP或者叫做业务IP,单个网卡当掉可以“漂”到其他网卡是继续提供服务 在Oracle RAC环境下,每 ...
- Oracle AWR 报告详解
转自:http://blog.csdn.net/laoshangxyc/article/details/8615187 持续更新中... Oracle awr报告详解 DB Name DB Id In ...
随机推荐
- ASP.NET内置对象
ASP.NET中有六个内置对象 Response:向客户端输出信息或设置客户端输出状态. Request:获取客户端信息. Server:访问服务器的方法和属性. Application:用于将信息保 ...
- Android Wear开发 - 数据通讯 - 第一节 : 连接数据层
http://developer.android.com/training/wearables/data-layer/accessing.html Accessing the Wearable Dat ...
- netstat详解
Netstat 命令用于显示各种网络相关信息,如网络连接,路由表,接口状态 (Interface Statistics),masquerade 连接,多播成员 (Multicast Membershi ...
- HDU 4283 You Are the One
题意:给定n(n<=100)个人,每个人有个固定的屌丝值D. 起初这些人是站成一行,当第i个人第j个去面试的时候他的值是 Di*j. 要求所有人面试之后 这些值加起来是最小的. 队伍站成一行(其 ...
- 1A Theatre Square
题目大意; 有一个广场,广场的大小是n*m, 有a*a的石砖,石砖铺广场可以比广场大,石砖不能切割.问最少需要多少个石砖. ===================================== ...
- Android Weekly Notes Issue #239
Android Weekly Issue #239 January 8th, 2017 Android Weekly Issue #239 本期内容包括: Android Things开发; Andr ...
- 如何在IIS6,7中部署ASP.NET网站
http://www.cnblogs.com/fish-li/archive/2012/02/26/2368989.html 阅读目录 开始 查看web.config文件 在IIS中创建网站 IIS6 ...
- 2013=10=19 ENGLISH 翻译
数据结构习题及答案 严蔚敏_课后习题答案 http://www.doc88.com/p-243584884293.html 273089354 随着女性获得平等权力的趋势,女性日渐增长的经济权力以及为 ...
- Storm-1.0.1+ZooKeeper-3.4.8+Netty-4.1.3 HA集群安装
Storm-1.0.1+ZooKeeper-3.4.8+Netty-4.1.3 HA集群安装 下载Storm-1.0.1 http://mirrors.tuna.tsinghua.edu.cn/apa ...
- 遍历Map的几种方法
public static void main(String[] args) { Map<String, String> map = new HashMap<String, Stri ...