百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

什么是 SQL 事务,如何创建 SQL 事务

liuian 2025-04-05 20:09 50 浏览

目录

  • 一、什么是事务
  • 二、创建事务
  • 三、ACID 特性

本文给大家介绍数据库中用来管理数据更新的重要概念——SQL 事务。简单来讲,事务就是需要在同一个处理单元中执行的一系列更新处理的集合。

本文重点

事务是需要在同一个处理单元中执行的一系列更新处理的集合。通过使用事务,可以对数据库中的数据更新处理的提交和取消进行管理。

事务处理的终止指令包括 COMMIT(提交处理)和 ROLLBACK(取消处理)两种。

DBMS 的事务具有原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)四种特性。通常将这四种特性的首字母结合起来,统称为 ACID 特性。

一、什么是事务

估计有些读者对事务(transaction)这个词并不熟悉,它通常被用于商务贸易或者经济活动中,但是在 RDBMS 中,事务是对表中数据进行更新的单位。简单来讲,事务就是需要在同一个处理单元中执行的一系列更新处理的集合

如 SQL 如何插入、删除和更新数据 所述,对表进行更新需要使用 INSERTDELETE 或者 UPDATE 三种语句。

但通常情况下,更新处理并不是执行一次就结束了,而是需要执行一系列连续的操作。这时,事务就能体现出它的价值了。

说到事务的例子,请大家思考一下下述情况。

现在,请大家把自己想象为管理 Product(商品)表的程序员或者软件工程师。销售部门的领导对你提出了如下要求。

“某某,经会议讨论,我们决定把 运动 T 恤 的销售单价下调 1000 元,同时把 T 恤衫 的销售单价上浮 1000 元,麻烦你去更新一下数据库。”

由于大家已经学习了更新数据的方法——只需要使用 UPDATE 进行更新就可以了,所以肯定会直接回答“知道了,请您放心吧”。

此时的事务由如下两条更新处理所组成。

  • 更新商品信息的事务
  • ① 将 运动 T 恤 的销售单价降低 1000
  • UPDATE ProductSET sale_price = sale_price - 1000WHERE product_name = '运动T恤';
  • ② 将 T 恤衫 的销售单价上浮 1000
  • UPDATE ProductSET sale_price = sale_price + 1000WHERE product_name = 'T恤衫';

上述 ① 和 ② 的操作一定要作为同一个处理单元执行。

如果只执行了 ① 的操作而忘记了执行 ② 的操作,或者反过来只执行了 ② 的操作而忘记了执行 ① 的操作,一定会受到领导的严厉批评。

遇到这种需要在同一个处理单元中执行一系列更新操作的情况,一定要使用事务来进行处理。

法则 7

事务是需要在同一个处理单元中执行的一系列更新处理的集合。

一个事务中包含多少个更新处理或者包含哪些处理,在 DBMS 中并没有固定的标准,而是根据用户的要求决定的(例如,运动 T 恤T 恤衫 的销售单价需要同时更新这样的要求,DBMS 是无法了解的)。

二、创建事务

如果想在 DBMS 中创建事务,可以按照如下语法结构编写 SQL 语句。

语法 6 事务的语法

事务开始语句;       DML语句①;      DML语句②;      DML语句③;         .         .         .事务结束语句(COMMIT或者ROLLBACK);

使用事务开始语句和事务结束语句,将一系列 DML 语句(INSERT/UPDATE/DELETE 语句)括起来,就实现了一个事务处理。

这时需要特别注意的是事务的开始语句 [1]。实际上,在标准 SQL 中并没有定义事务的开始语句,而是由各个 DBMS 自己来定义的。比较有代表性的语法如下所示。

  • SQL Server、PostgreSQL
  • BEGIN TRANSACTION
  • MySQL
  • START TRANSACTION
  • Oracle、DB2

例如使用之前的那两个 UPDATE(① 和 ②)创建出的事务如代码清单 21 所示。

代码清单 21 更新商品信息的事务

SQL Server PostgreSQL

BEGIN TRANSACTION;     -- 将运动T恤的销售单价降低1000日元    UPDATE Product       SET sale_price = sale_price - 1000     WHERE product_name = '运动T恤';     -- 将T恤衫的销售单价上浮1000日元    UPDATE Product       SET sale_price = sale_price + 1000     WHERE product_name = 'T恤衫'; COMMIT;

MySQL

START TRANSACTION;     -- 将运动T恤的销售单价降低1000日元    UPDATE Product       SET sale_price = sale_price - 1000     WHERE product_name = '运动T恤';     -- 将T恤衫的销售单价上浮1000日元    UPDATE Product       SET sale_price = sale_price + 1000     WHERE product_name = 'T恤衫'; COMMIT;

Oracle DB2

-- 将运动T恤的销售单价降低1000日元UPDATE Product   SET sale_price = sale_price - 1000 WHERE product_name = '运动T恤'; -- 将T恤衫的销售单价上浮1000日元UPDATE Product   SET sale_price = sale_price + 1000 WHERE product_name = 'T恤衫'; COMMIT;

如上所示,各个 DBMS 事务的开始语句都不尽相同,其中 Oracle 和 DB2 并没有定义特定的开始语句。

可能大家觉得这样的设计很巧妙,其实是因为标准 SQL 中规定了一种悄悄开始事务处理 [2] 的方法。

因此,即使是经验丰富的工程师也经常会忽略事务处理开始的时间点。大家可以试着通过询问“是否知道某个 DBMS 中事务是什么时候开始的”,来测试学校或者公司前辈的数据库知识。

反之,事务的结束需要用户明确地给出指示。结束事务的指令有如下两种。

  • COMMIT——提交处理
  • COMMIT 是提交事务包含的全部更新处理的结束指令(图 3),相当于文件处理中的覆盖保存。一旦提交,就无法恢复到事务开始前的状态了。
  • 因此,在提交之前一定要确认是否真的需要进行这些更新。
  • 图 3 COMMIT 的流程 = 直线进行
  • 万一由于误操作提交了包含错误更新的事务,就只能回到重新建表、重新插入数据这样繁琐的老路上了。
  • 由于可能会造成数据无法恢复的后果,请大家一定要注意(特别是在执行 DELETE 语句的 COMMIT 时尤其要小心)。
  • 法则 8
  • 虽然我们可以不清楚事务开始的时间点,但是在事务结束时一定要仔细进行确认。
  • ROLLBACK——取消处理
  • ROLLBACK 是取消事务包含的全部更新处理的结束指令(图 4),相当于文件处理中的放弃保存。一旦回滚,数据库就会恢复到事务开始之前的状态(代码清单 22)。
  • 通常回滚并不会像提交那样造成大规模的数据损失。
  • 图 4 ROLLBACK 的流程 = 掉头回到起点
  • 代码清单 22 事务回滚的例子
  • SQL Server PostgreSQL
  • BEGIN TRANSACTION; ------------------- ① -- 将运动T恤的销售单价降低1000日元 UPDATE Product SET sale_price = sale_price - 1000 WHERE product_name = '运动T恤'; -- 将T恤衫的销售单价上浮1000日元 UPDATE Product SET sale_price = sale_price + 1000 WHERE product_name = 'T恤衫'; ROLLBACK;
  • 特定的 SQL
  • 至此,我们已经知道各个 DBMS 中关于事务的语法不尽相同。
  • 代码清单 22 中的语句在 MySQL 中执行时需要将 ① 语句改写为“START TRANSACTION”,而在 Oracle 和 DB2 中执行时则无需 ① 语句(请将其删除),具体请参考上一节的“创建事务”。
  • 上述事务处理执行之后,表中的数据不会发生任何改变。这是因为执行最后一行的 ROLLBACK 之后,所有的处理都被取消了。
  • 因此,回滚执行起来就无需像提交时那样小心翼翼了(即使是想要提交的情况,也只需要重新执行事务处理就可以了)。

专栏

事务处理何时开始

之前我们说过,事务并没有标准的开始指令存在,而是根据 DBMS 的不同而不同。

实际上,几乎所有的数据库产品的事务都无需开始指令。这是因为大部分情况下,事务在数据库连接建立时就已经悄悄开始了,并不需要用户再明确发出开始指令。

例如,使用 Oracle 时,数据库连接建立之后,第一条 SQL 语句执行的同时,事务就已经悄悄开始了。

像这样不使用指令而悄悄开始事务的情况下,应该如何区分各个事务呢?通常会有如下两种情况。

A:每条 SQL 语句就是一个事务(自动提交模式

B:直到用户执行 COMMIT 或者 ROLLBACK 为止算作一个事务

通常的 DBMS 都可以选择其中任意一种模式。默认使用自动提交模式的 DBMS 有 SQL Server、PostgreSQL 和 MySQL 等 13 DML 语句如下所示,每一条语句都括在事务的开始语句和结束语句之中。

BEGIN TRANSACTION; -- 将运动T恤的销售单价降低1000日元 UPDATE Product SET sale_price = sale_price - 1000 WHERE product_name = '运动T恤';COMMIT; BEGIN TRANSACTION; -- 将T恤衫的销售单价上浮1000日元 UPDATE Product SET sale_price = sale_price + 1000 WHERE product_name = 'T恤衫';COMMIT;

在默认使用 B 模式的 Oracle 中,事务都是直到用户自己执行提交或者回滚指令才会结束。

自动提交的情况需要特别注意的是 DELETE 语句。

如果不是自动提交,即使使用 DELETE 语句删除了数据表,也可以通过 ROLLBACK 命令取消该事务的处理,恢复表中的数据。

但这仅限于明示开始事务,或者关闭自动提交的情况。如果不小心在自动提交模式下执行了 DELETE 操作,即使再回滚也无济于事了。

这是一个很严重的问题,初学者难免会碰到这样的麻烦。一旦误删了数据,如果无法重新插入,是不是想哭的心都有了?所以一定要特别小心。

三、ACID 特性

DBMS 的事务都遵循四种特性,将这四种特性的首字母结合起来统称为 ACID 特性。这是所有 DBMS 都必须遵守的规则。

  • 原子性(Atomicity)
  • 原子性是指在事务结束时,其中所包含的更新处理要么全部执行,要么完全不执行,也就是要么占有一切要么一无所有。
  • 例如,在之前的例子中,在事务结束时,绝对不可能出现 运动 T 恤 的价格下降了,而 T 恤衫 的价格却没有上涨的情况。
  • 该事务的结束状态,要么是两者都执行了(COMMIT),要么是两者都未执行(ROLLBACK)。
  • 从事务中途停止的角度去考虑,就能比较容易理解原子性的重要性了。
  • 由于用户在一个事务中定义了两条 UPDATE 语句,DBMS 肯定不会只执行其中一条,否则就会对业务处理造成影响。
  • 一致性(Consistency)
  • 一致性指的是事务中包含的处理要满足数据库提前设置的约束,如主键约束或者 NOT NULL 约束等。
  • 例如,设置了 NOT NULL 约束的列是不能更新为 NULL 的,试图插入违反主键约束的记录就会出错,无法执行。
  • 对事务来说,这些不合法的 SQL 会被回滚。也就是说,这些 SQL 处理会被取消,不会执行。
  • 一致性也称为完整性(图 5)。
  • 图 5 保持完整性的流程
  • 隔离性(Isolation)
  • 隔离性指的是保证不同事务之间互不干扰的特性。该特性保证了事务之间不会互相嵌套。此外,在某个事务中进行的更改,在该事务结束之前,对其他事务而言是不可见的。
  • 因此,即使某个事务向表中添加了记录,在没有提交之前,其他事务也是看不到新添加的记录的。
  • 持久性(Durability)
  • 持久性也可以称为耐久性,指的是在事务(不论是提交还是回滚)结束后,DBMS 能够保证该时间点的数据状态会被保存的特性。
  • 即使由于系统故障导致数据丢失,数据库也一定能通过某种手段进行恢复。
  • 如果不能保证持久性,即使是正常提交结束的事务,一旦发生了系统故障,也会导致数据丢失,一切都需要从头再来。
  • 保证持久性的方法根据实现的不同而不同,其中最常见的就是将事务的执行记录保存到硬盘等存储介质中(该执行记录称为日志)。
  • 当发生故障时,可以通过日志恢复到故障发生前的状态。

  1. 与之相对,事务结束语句只有 COMMITROLLBACK 两种,在所有的 RDBMS 中都是通用的。
  2. 《标准 SQL 手册修订第 4 版》中的记述:希望大家注意事务默认开始的时间点。没有“BEGIN TRANSACTION”这样明确的开始标志。

相关推荐

驱动网卡(怎么从新驱动网卡)
驱动网卡(怎么从新驱动网卡)

网卡一般是指为电脑主机提供有线无线网络功能的适配器。而网卡驱动指的就是电脑连接识别这些网卡型号的桥梁。网卡只有打上了网卡驱动才能正常使用。并不是说所有的网卡一插到电脑上面就能进行数据传输了,他都需要里面芯片组的驱动文件才能支持他进行数据传输...

2026-01-30 00:37 liuian

win10更新助手装系统(微软win10更新助手)

1、点击首页“系统升级”的按钮,给出弹框,告诉用户需要上传IMEI码才能使用升级服务。同时给出同意和取消按钮。华为手机助手2、点击同意,则进入到“系统升级”功能华为手机助手华为手机助手3、在检测界面,...

windows11专业版密钥最新(windows11专业版激活码永久)

 Windows11专业版的正版密钥,我们是对windows的激活所必备的工具。该密钥我们可以通过微软商城或者通过计算机的硬件供应商去购买获得。获得了windows11专业版的正版密钥后,我...

手机删过的软件恢复(手机删除过的软件怎么恢复)
手机删过的软件恢复(手机删除过的软件怎么恢复)

操作步骤:1、首先,我们需要先打开手机。然后在许多图标中找到带有[文件管理]文本的图标,然后单击“文件管理”进入页面。2、进入页面后,我们将在顶部看到一行文本:手机,最新信息,文档,视频,图片,音乐,收藏,最后是我们正在寻找的[更多],单击...

2026-01-29 23:55 liuian

一键ghost手动备份系统步骤(一键ghost 备份)

  步骤1、首先把装有一键GHOST装系统的U盘插在电脑上,然后打开电脑马上按F2或DEL键入BIOS界面,然后就选择BOOT打USDHDD模式选择好,然后按F10键保存,电脑就会马上重启。  步骤...

怎么创建局域网(怎么创建局域网打游戏)

  1、购买路由器一台。进入路由器把dhcp功能打开  2、购买一台交换机。从路由器lan端口拉出一条网线查到交换机的任意一个端口上。  3、两台以上电脑。从交换机任意端口拉出网线插到电脑上(电脑设置...

精灵驱动器官方下载(精灵驱动手机版下载)

是的。驱动精灵是一款集驱动管理和硬件检测于一体的、专业级的驱动管理和维护工具。驱动精灵为用户提供驱动备份、恢复、安装、删除、在线更新等实用功能。1、全新驱动精灵2012引擎,大幅提升硬件和驱动辨识能力...

一键还原系统步骤(一键还原系统有哪些)

1、首先需要下载安装一下Windows一键还原程序,在安装程序窗口中,点击“下一步”,弹出“用户许可协议”窗口,选择“我同意该许可协议的条款”,并点击“下一步”。  2、在弹出的“准备安装”窗口中,可...

电脑加速器哪个好(电脑加速器哪款好)

我认为pp加速器最好用,飞速土豆太懒,急速酷六根本不工作。pp加速器什么网页都加速,太任劳任怨了!以上是个人观点,具体性能请自己试。ps:我家电脑性能很好。迅游加速盒子是可以加速电脑的。因为有过之...

任何u盘都可以做启动盘吗(u盘必须做成启动盘才能装系统吗)

是的,需要注意,U盘的大小要在4G以上,最好是8G以上,因为启动盘里面需要装系统,内存小的话,不能用来安装系统。内存卡或者U盘或者移动硬盘都可以用来做启动盘安装系统。普通的U盘就可以,不过最好U盘...

u盘怎么恢复文件(u盘文件恢复的方法)

开360安全卫士,点击上面的“功能大全”。点击文件恢复然后点击“数据”下的“文件恢复”功能。选择驱动接着选择需要恢复的驱动,选择接入的U盘。点击开始扫描选好就点击中间的“开始扫描”,开始扫描U盘数据。...

系统虚拟内存太低怎么办(系统虚拟内存占用过高什么原因)

1.检查系统虚拟内存使用情况,如果发现有大量的空闲内存,可以尝试释放一些不必要的进程,以释放内存空间。2.如果系统虚拟内存使用率较高,可以尝试增加系统虚拟内存的大小,以便更多的应用程序可以使用更多...

剪贴板权限设置方法(剪贴板访问权限)
剪贴板权限设置方法(剪贴板访问权限)

1、首先打开iphone手机,触碰并按住单词或图像直到显示选择选项。2、其次,然后选取“拷贝”或“剪贴板”。3、勾选需要的“权限”,最后选择开启,即可完成苹果剪贴板权限设置。仅参考1.打开苹果手机设置按钮,点击【通用】。2.点击【键盘】,再...

2026-01-29 21:37 liuian

平板系统重装大师(平板重装win系统)

如果你的平板开不了机,但可以连接上电脑,那就能好办,楼主下载安装个平板刷机王到你的个人电脑上,然后连接你的平板,平板刷机王会自动识别你的平板,平板刷机王上有你平板的我刷机包,楼主点击下载一个,下载完成...

联想官网售后服务网点(联想官网售后服务热线)

联想3c服务中心是联想旗下的官方售后,是基于互联网O2O模式开发的全新服务平台。可以为终端用户提供多品牌手机、电脑以及其他3C类产品的维修、保养和保险服务。根据客户需求层次,联想服务针对个人及家庭客户...