事务处理概述

一、引言

1、决定数据库应用系统性能的DBMS的关键实现技术------事务处理技术

事务处理技术是为了解决早期的DBMS产品在应用过程中遇到的现实问题而在后续的DBMS产品中加以实现的技术

2、比如在银行系统中,账户转账是常见的业务,是金融学中的交易transcation。若银行用户在ATM机上进行转账操作,从A账户转账1000元到B账户,银行的账户信息一般存储在关系型DBMS所管理的数据库中。假如用户账户信息存储数据库中Accounts关系表中,有账户号码acctNo和余额balance两个属性,同时设定不能透支转账约束,那么如何实现从A账户转账1000元到B账户的操作呢 ?

从用户的观点,资金转账是一个完整的业务,是一笔交易,是一个独立的操作。而在应用系统中,需要再应用程序中嵌入SQL语句,由如下两个数据库操作来完成数据库中数据的更新

但是在应用程序的执行过程中,在执行第一个更新操作之后和第二个更新操作之前,可能会出现计算机停止运转等故障,使得前一个操作完成而后一个操作没有执行,从而导致1000元资金从账户A中支出但并没有存入账户B中,出现了数据库中的数据与业务结果的不一致,对用户来说,要么转账成功,要么不能转账,这是用户所能接受的,而其他错误是不能允许的。

对于两个不同的账户,例如账户B和账户C,同时向同一个账户,例如账户A转账,还可能出现分别从账户B和账户C支出了500元和1000元,而在账户A中却只存入了500元或1000元,而不是存入1500元的现象。两个转账业务可分别正确执行,但并发执行时可能全局结果不对,也出现了数据库中的数据与业务结果不一致的问题。

这些问题会经常出现在DBMS的早期应用中,使得在数据库理论相对成熟后,相当长的一段时间DBMS产品无法广泛应用

二、事务概念的提出

1、1976年,Jim Gray在数据库领域引入了Transaction事务的概念,提出了事务处理技术来解决这些问题,使得DBMS在实现事务处理机制以后得到了广发的引用,成为了数据库技术应用于银行、金融等行业的基础

2、Jim Gray在事务处理技术上的创造性思维和开拓性研究成果,反应在其专著《事务处理:概念与技术》一书中

3、Jim Gray也因此获得了1998年的图灵奖

三、后续

之后,我将会从事务的概念、如何用SQL语言定义一个事务、阐述事务作为数据库的逻辑工作单元应具有的原子性、一致性、隔离性和持久性等特性、事务处理的两个重要方面:数据恢复和并发控制四个部分来进一步学习事务

相关推荐
treacle田24 分钟前
达梦数据库-达梦数据库中link链接访问远程Sql Sever-记录总结
数据库·达梦-sqlserver
ClouGence26 分钟前
不用搭复杂系统,也能做跨地域数据迁移?
大数据·数据库·saas
xcjbqd028 分钟前
SQL中视图能否嵌套存储过程_实现复杂自动化报表逻辑
jvm·数据库·python
听*雨声40 分钟前
软件设计师上午题5:数据库
数据库
hong78171 小时前
阿里coding plan qwen3.6-plus 不支持图片上下文长度只有200K,问题出在哪?
linux·运维·数据库
Paxon Zhang1 小时前
MySQL 大师之路**数据库约束,表设计,CRUD**
android·数据库·mysql
HealthScience1 小时前
clinvar数据集说明
数据库·oracle
王的宝库2 小时前
【MySQL】主从复制原理详解:从 Binlog 到数据一致性
数据库·mysql
Vect__2 小时前
MySQL基本认知、库和表的操作
数据库·mysql
cyber_两只龙宝2 小时前
【Oracle】Oracle之DQL中SELECT的基础使用
linux·运维·服务器·数据库·云原生·oracle