事务处理概述

一、引言

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

相关推荐
無限進步D2 分钟前
MySQL 单行函数
数据库·mysql
AI人工智能+电脑小能手38 分钟前
【大白话说Java面试题 第77题】【Mysql篇】第7题:回表查询与全表扫描的区别?
java·开发语言·数据库·mysql·面试
项目工具测评实验室1 小时前
复杂项目管理工具选型:飞书项目、PingCode、ONES 深度对比与真实场景分析
数据库·飞书·pingcode
Drache_long1 小时前
CentOS7安装Oracle数据库
数据库·oracle
auspicious航2 小时前
PostgreSQL逻辑复制全解析:从原理到跨区域实战
数据库·postgresql
無限進步D2 小时前
MySQL 聚合函数
数据库·mysql
许彰午3 小时前
开发转兼职DBA(四):又起不来了——MVCC、undo与回滚段
数据库·dba
就叫飞六吧3 小时前
生产数据库批量 UPDATE / DELETE 核心要点-不备份=自行提桶跑路
数据库·sql·mysql
deepin_sir3 小时前
05 Chroma_高级检索:过滤、距离算法与元数据魔法
网络·数据库·算法
聚美智数3 小时前
邮箱验证-电子邮件地址校验-邮件地址验证-邮箱校验接口介绍
java·开发语言·数据库