事务处理概述

一、引言

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语言定义一个事务、阐述事务作为数据库的逻辑工作单元应具有的原子性、一致性、隔离性和持久性等特性、事务处理的两个重要方面:数据恢复和并发控制四个部分来进一步学习事务

相关推荐
不再幻想,脚踏实地17 分钟前
Spring Boot配置文件
java·数据库·spring boot
_extraordinary_19 分钟前
MySQL 事务(二)
android·数据库·mysql
fmdpenny38 分钟前
SQL中联表的运用
数据库·sql
不剪发的Tony老师44 分钟前
互联网SQL面试题:用户会话时长分析
数据库·sql
睡觉z1 小时前
Shell编程之正则表达式与文本处理器
数据库·mysql·正则表达式
TDengine (老段)1 小时前
TDengine 做为 Spark 数据源
大数据·数据库·物联网·ajax·spark·时序数据库·tdengine
Dreams_l1 小时前
MySQL初阶:查询进阶
数据库·mysql
码农黛兮_461 小时前
数据库数据清洗、预处理与质量监控、 数据质量的核心概念
数据库
张哈大3 小时前
【 Redis | 实战篇 秒杀实现 】
数据库·redis·缓存
weixin_472339463 小时前
Postgresql与openguass对比
数据库·postgresql