当前位置: 首页 > article >正文

SQL Server 事务详解:概念、特性、隔离级别与实践

一、事务的基本概念

事务(Transaction)是数据库操作的基本单位,它是由一组SQL语句组成的逻辑工作单元。事务具有以下关键特性,通常被称为ACID特性:

  1. ​原子性(Atomicity)​​:事务是一个不可分割的工作单位,事务中的操作要么全部成功,要么全部失败回滚。
  2. ​一致性(Consistency)​​:事务执行前后,数据库从一个一致状态变到另一个一致状态。
  3. ​隔离性(Isolation)​​:多个事务并发执行时,一个事务的执行不应影响其他事务的执行。
  4. ​持久性(Durability)​​:事务一旦提交,它对数据库的改变就是永久性的,即使系统崩溃也不会丢失。

二、事务的创建与控制

1. 显式事务

显式事务需要使用BEGIN TRANSACTION、COMMIT TRANSACTION和ROLLBACK TRANSACTION语句来显式地定义事务的开始、提交和回滚。

BEGIN TRANSACTION;  -- 开始事务-- 执行一系列SQL语句
UPDATE Accounts SET Balance = Balance - 100 WHERE AccountID = 1;
UPDATE Accounts SET Balance = Balance + 100 WHERE AccountID = 2;-- 检查是否有错误
IF @@ERROR <> 0
BEGINROLLBACK TRANSACTION;  -- 回滚事务PRINT 'Transaction rolled back due to error';
END
ELSE
BEGINCOMMIT TRANSACTION;  -- 提交事务PRINT 'Transaction committed successfully';
END

2. 隐式事务

SQL Server也支持隐式事务模式,当启用隐式事务后,每个SQL语句都会自动被视为一个事务,除非显式地提交或回滚。

SET IMPLICIT_TRANSACTIONS ON;  -- 启用隐式事务-- 每个语句都是一个独立的事务
UPDATE Accounts SET Balance = Balance - 100 WHERE AccountID = 1;
UPDATE Accounts SET Balance = Balance + 100 WHERE AccountID = 2;COMMIT TRANSACTION;  -- 提交当前事务-- 下一个语句将开始新的事务
UPDATE Accounts SET Balance = Balance - 50 WHERE AccountID = 3;

3. 自动提交事务

这是SQL Server的默认模式。每个单独的SQL语句都被视为一个独立的事务,执行后立即提交。

三、事务的控制语句

1. BEGIN TRANSACTION

标记事务的开始。可以指定事务名称,便于在错误处理时引用:

BEGIN TRANSACTION TransferFunds;

2. COMMIT TRANSACTION

提交事务,使所有更改永久生效。

COMMIT TRANSACTION TransferFunds;

3. ROLLBACK TRANSACTION

回滚事务,撤销自事务开始以来的所有更改。

ROLLBACK TRANSACTION TransferFunds;

4. SAVE TRANSACTION

保存事务的当前状态,可以在后续使用ROLLBACK TRANSACTION保存点名来回滚到该点:

BEGIN TRANSACTION TransferFunds;-- 执行一些操作
UPDATE Accounts SET Balance = Balance - 100 WHERE AccountID = 1;-- 保存当前状态
SAVE TRANSACTION BeforeUpdate2;-- 执行更多操作
UPDATE Accounts SET Balance = Balance + 100 WHERE AccountID = 2;-- 如果出错,可以回滚到保存点
IF @@ERROR <> 0
BEGINROLLBACK TRANSACTION BeforeUpdate2;PRINT 'Rolled back to BeforeUpdate2';
END
ELSE
BEGINCOMMIT TRANSACTION TransferFunds;
END

四、事务的隔离级别

SQL Server支持多种隔离级别,控制并发事务之间的可见性和影响程度。可以通过SET TRANSACTION ISOLATION LEVEL语句设置隔离级别。

1. READ UNCOMMITTED(读未提交)

最低的隔离级别,允许读取其他事务未提交的更改(脏读)。性能最高,但数据一致性最差。

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;

2. READ COMMITTED(读已提交)

默认隔离级别。只能读取已提交的数据,防止脏读,但允许不可重复读和幻读。

SET TRANSACTION ISOLATION LEVEL READ COMMITTED;

3. REPEATABLE READ(可重复读)

防止脏读和不可重复读,但允许幻读。事务在读取数据时会锁定这些数据,防止其他事务修改。

SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;

4. SERIALIZABLE(可序列化)

最高的隔离级别,防止脏读、不可重复读和幻读。通过锁定整个范围的数据来防止幻读。

SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;

5. SNAPSHOT(快照)

基于行版本控制的隔离级别,提供一致的数据视图而不锁定数据。需要数据库启用快照隔离。

SET TRANSACTION ISOLATION LEVEL SNAPSHOT;

五、事务的错误处理

在事务中处理错误非常重要,可以使用TRY...CATCH块来捕获和处理错误:

BEGIN TRYBEGIN TRANSACTION;-- 执行业务逻辑UPDATE Accounts SET Balance = Balance - 100 WHERE AccountID = 1;UPDATE Accounts SET Balance = Balance + 100 WHERE AccountID = 2;-- 检查是否有错误IF @@ERROR <> 0THROW;  -- 抛出错误COMMIT TRANSACTION;PRINT 'Transaction completed successfully';
END TRY
BEGIN CATCHIF @@TRANCOUNT > 0ROLLBACK TRANSACTION;PRINT 'Error occurred: ' + ERROR_MESSAGE();PRINT 'Error number: ' + CAST(ERROR_NUMBER() AS VARCHAR);PRINT 'Error severity: ' + CAST(ERROR_SEVERITY() AS VARCHAR);PRINT 'Error state: ' + CAST(ERROR_STATE() AS VARCHAR);
END CATCH

六、事务的锁定与阻塞

1. 锁的类型

SQL Server使用锁来保证事务的隔离性,主要锁类型包括:

  • ​共享锁(S锁)​​:用于读操作,允许多个事务同时读取数据,但阻止其他事务获取排他锁。
  • ​排他锁(X锁)​​:用于写操作,阻止其他事务获取任何类型的锁。
  • ​更新锁(U锁)​​:用于在读取数据以确定是否需要更新时使用,可以防止死锁。
  • ​意向锁​​:用于指示事务将在锁定的对象上获取的锁类型。

2. 锁的粒度

SQL Server可以在不同粒度上锁定数据:

  • ​行锁(Row Lock)​​:锁定单行数据。
  • ​页锁(Page Lock)​​:锁定数据页(通常包含多行)。
  • ​表锁(Table Lock)​​:锁定整个表。
  • ​数据库锁(Database Lock)​​:锁定整个数据库。

3. 阻塞与死锁

  • ​阻塞​​:当一个事务持有锁而另一个事务需要相同的锁时,后者会被阻塞,直到前者释放锁。
  • ​死锁​​:两个或多个事务相互等待对方释放锁,形成循环等待,SQL Server会自动检测并终止其中一个事务以打破死锁。

七、事务的最佳实践

  1. ​保持事务简短​​:事务应尽可能短,以减少锁定时间和资源争用。
  2. ​避免长事务​​:长时间运行的事务会阻塞其他事务,影响系统性能。
  3. ​合理设置隔离级别​​:根据业务需求选择适当的隔离级别,平衡一致性和性能。
  4. ​使用错误处理​​:始终使用TRY...CATCH块处理事务中的错误,确保在出错时回滚事务。
  5. ​监控锁和阻塞​​:定期监控数据库中的锁和阻塞情况,优化事务设计。
  6. ​考虑使用批处理​​:对于大量数据操作,考虑将操作分解为多个小事务或使用批处理技术。
  7. ​避免在事务中执行非必要操作​​:如用户交互、网络调用等,这些操作会延长事务时间。

八、事务与性能

事务对数据库性能有重要影响:

  • ​锁争用​​:过多或过长时间的事务会导致锁争用,降低并发性能。
  • ​日志记录​​:事务日志记录会影响I/O性能,特别是在大事务中。
  • ​资源占用​​:事务会占用数据库资源,如锁、内存等。

优化事务性能的策略包括:

  1. ​减少事务大小​​:只包含必要的操作。
  2. ​优化查询​​:确保事务中的SQL语句高效执行。
  3. ​合理使用索引​​:提高查询性能,减少锁定时间。
  4. ​批量操作​​:对于大量数据操作,使用批量处理技术。
  5. ​适当隔离级别​​:根据业务需求选择最低必要的隔离级别。

九、总结

SQL Server事务是确保数据一致性和完整性的关键机制。理解事务的ACID特性、控制语句、隔离级别以及错误处理对于开发可靠的数据库应用程序至关重要。同时,合理设计事务以平衡一致性和性能也是数据库开发中的重要技能。通过遵循最佳实践和监控事务行为,可以构建高效、可靠的数据库系统。

相关文章:

SQL Server 事务详解:概念、特性、隔离级别与实践

一、事务的基本概念 事务&#xff08;Transaction&#xff09;是数据库操作的基本单位&#xff0c;它是由一组SQL语句组成的逻辑工作单元。事务具有以下关键特性&#xff0c;通常被称为ACID特性&#xff1a; ​​原子性&#xff08;Atomicity&#xff09;​​&#xff1a;事务…...

MAC软件游戏打开提示已损坏

打开「终端.app」&#xff0c;输入以下命令并回车&#xff0c;输入开机密码回车 sudo spctl --master-disable 按照上述步骤操作完成后&#xff0c;打开「系统偏好设置」-「安全与隐私」-「通用」&#xff0c;确保已经修改为「任何来源」。 打开「终端.app」&#xff0c;输入…...

React基础教程(13):路由的使用

文章目录 1、什么是路由?2、路由安装3、路由使用(1)路由方法导入和使用(2)定义路由以及重定向(3)嵌套路由(4)路由跳转方式(5)动态路由动态路由写法一动态路由写法二4、实现效果5、完整代码下载1、什么是路由? 路由是根据不同的url地址展示不同的内容或页面。 一个…...

力扣刷题(第四十三天)

灵感来源 - 保持更新&#xff0c;努力学习 - python脚本学习 解题思路 1. 逐位检查法&#xff1a;通过右移操作逐位检查每一位是否为1&#xff0c;统计计数 2. 位运算优化法&#xff1a;利用 n & (n-1) 操作消除最低位的1&#xff0c;减少循环次数 3. 内置函数法&…...

Centos环境下安装/重装MySQL完整教程

目录 一、卸载残留的MySQL环境&#xff1a; 二、安装MySQL&#xff1a; 1、下载MySQL官方的yum源&#xff1a; 2、更新系统yum源&#xff1a; 3、确保系统中有了对应的MySQL安装包&#xff1a; 4、安装MySQL服务&#xff1a; 5、密钥问题安装失败解决方法&#xff1a; …...

【Linux】环境变量完全解析

9.环境变量 文章目录 9.环境变量一、命令行参数二、获取环境变量程序中获取环境变量1. 使用命令行参数2. 使用系统调用函数getenv("字符串");3. 使用系统提供的全局变量environ 命令行中查询环境变量 三、常见环境变量1. HOME2. OLDPWD3. PATH4. SHELL 四、环境变量与…...

【Java】mybatis-plus乐观锁-基本使用

乐观锁&#xff08;Optimistic Locking&#xff09;是解决并发问题的重要机制。它通过在数据更新时验证数据版本来确保数据的一致性&#xff0c;从而避免并发冲突。与悲观锁不同&#xff0c;乐观锁并不依赖数据库的锁机制&#xff0c;而是通过检查数据的版本或标志字段来判断数…...

力扣每日一题——找到离给定两个节点最近的节点

目录 题目链接&#xff1a;2359. 找到离给定两个节点最近的节点 - 力扣&#xff08;LeetCode&#xff09; 题目描述 解法一&#xff1a;双指针路径交汇法​ 基本思路 关键步骤 为什么这样可行呢我请问了&#xff1f; 举个例子 特殊情况 Java写法&#xff1a; C写法&a…...

机器学习与深度学习03-逻辑回归01

目录 上集回顾1. 逻辑回归与线性回归的区别2.逻辑回归的常见目标函数3.逻辑回归如何分类4.Sigmoid函数详解5.逻辑回归模型的参数 上集回顾 上一节文章地址&#xff1a;链接 1. 逻辑回归与线性回归的区别 应用领域 线性回归通常⽤于解决回归问题&#xff0c;其中⽬标是预测⼀…...

卷积神经网络(CNN)入门学习笔记

什么是 CNN&#xff1f; CNN&#xff0c;全称 卷积神经网络&#xff08;Convolutional Neural Network&#xff09;&#xff0c;是一种专门用来处理图片、语音、文本等结构化数据的神经网络。 它模仿人眼识别图像的方式&#xff1a; 从局部到整体&#xff0c;一步步提取特征&a…...

【优笔】基于STM32的多模态智能门禁系统

代码功能详细描述 该代码实现了一个基于STM32的多模态智能门禁系统,整合密码、指纹、人脸识别(预留)三种验证方式,并提供完善的管理功能。系统架构如下图所示: #mermaid-svg-Uufpcoeo5Lega096 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size…...

Metasploit工具使用详解(上)丨小白WEB安全入门笔记

Metasploit工具使用详解(上)丨小白WEB安全入门笔记 一、课程定位与工具概述 课程性质&#xff1a; 小白WEB安全入门课程聚焦基础操作&#xff0c;非深度专题&#xff08;Metasploit专题可讲数十节课&#xff09;目标&#xff1a;掌握基本概念和简单漏洞利用 Metasploit核心定…...

Femap许可证与网络安全策略

随着科技的快速发展&#xff0c;网络安全问题已成为各行各业关注的焦点。在电磁仿真领域&#xff0c;Femap作为一款领先的软件&#xff0c;其许可证的安全性和网络策略的重要性不言而喻。本文将探讨Femap许可证与网络安全策略的关系&#xff0c;确保您的电磁仿真工作能够在一个…...

VLAN的作用和原理

1. 为什么要有vlan&#xff1f; 分割广播域&#xff0c;避免广播风暴&#xff0c;造成网络资源的浪费 可以灵活的组网&#xff0c;便于管理&#xff0c;同时还有安全加固的功能 2. vlan是怎么实现的&#xff1f;端口的原理&#xff1f; 设置VLAN后&#xff0c;流量之间的转…...

深入探讨集合与数组转换方法

目录 1、Arrays.asList() 1.1、方法作用 1.2、内部实现 1.3、修改元素的影响 1.4、注意事项 2、list.toArray() 2.1、方法作用 2.2、内部实现 2.3、修改元素的影响 2.4、特殊情况 1、对象引用 2、数组copy 3、对比总结 4、常见误区与解决方案 5、实际应用建议…...

让大模型看得见自己的推理 — KnowTrace结构化知识追踪

让大模型“看得见”自己的推理 —— KnowTrace 结构化知识追踪式 RAG 全解析 一句话概括:把检索-推理“改造”成 动态知识图构建任务,再让 LLM 只关注这张不断精炼的小图 —— 这就是显式知识追踪的核心价值。 1. 背景:为什么 RAG 仍难以搞定多跳推理? 长上下文负担 传统 I…...

【HarmonyOS 5应用架构详解】深入理解应用程序包与多Module设计机制

⭐本期内容&#xff1a;【HarmonyOS 5应用架构详解】深入理解应用程序包与多Module设计机制 &#x1f3c6;系列专栏&#xff1a;鸿蒙HarmonyOS&#xff1a;探索未来智能生态新纪元 文章目录 前言应用与应用程序包应用程序的基本概念应用程序包的类型标识机制应用安装流程 应用的…...

【Oracle】DCL语言

个人主页&#xff1a;Guiat 归属专栏&#xff1a;Oracle 文章目录 1. DCL概述1.1 什么是DCL&#xff1f;1.2 DCL的核心功能 2. 用户管理2.1 创建用户2.2 修改用户2.3 删除用户2.4 用户信息查询 3. 权限管理3.1 系统权限3.1.1 授予系统权限3.1.2 撤销系统权限 3.2 对象权限3.2.1…...

MySQL强化关键_017_索引

目 录 一、概述 二、索引 1.主键索引 2.唯一索引 3.查看索引 4.添加索引 &#xff08;1&#xff09;建表时添加 &#xff08;2&#xff09;建表后添加 5.删除索引 三、树 1.二叉树 2.红黑树 3.B树 4.B树 &#xff08;1&#xff09;为什么 MySQL 选择B树作为索引…...

stm32——SPI协议

stm32——SPI协议 STM32的SPI&#xff08;Serial Peripheral Interface&#xff0c;串行外设接口&#xff09;协议是一种高速、全双工、同步的串行通信协议&#xff0c;广泛评估微控制器与各种外设&#xff08;如传感器、器件、显示器、模块等&#xff09;之间的数据传输。STM3…...

Linux 下如何查看进程的资源限制信息?

简介 Linux 上的 cat /proc/$pid/limits 命令提供有关特定进程的资源限制的信息&#xff0c;其中 $pid 是相关进程的进程 ID &#xff08;pid&#xff09;。该文件是 /proc 文件系统的一部分&#xff0c;该文件系统是一个虚拟文件系统&#xff0c;提供有关进程和系统资源的信息…...

【备忘】php命令行异步执行超长时间任务

环境说明&#xff1a; 操作系统&#xff1a;windows10 IDE&#xff1a;phpstorm 开发语言&#xff1a;php7.4 框架&#xff1a;thinkphp5.1 测试环境&#xff1a;linuxwindows均测试通过。 初级方法&#xff1a; function longRunningTask() {$root_path Tools::get_ro…...

对于ARM开发各种手册的分类

手册名称全称主要内容适用范围是不是讲SysTick&#xff1f;Cortex-M3 Technical Reference Manual (TRM)Cortex-M3 Technical Reference Manual描述 Cortex-M3内核架构&#xff0c;如寄存器模型、总线接口、指令集、异常模型只适合 Cortex-M3 内核&#xff0c;不含外设❌ 没有C…...

java开发中#和$的区别

在Spring框架中&#xff0c;$ 和 # 是两种不同的表达式前缀&#xff0c;用于从不同的来源获取值或执行计算。下面详细解释它们的区别和用法&#xff1a; 一、$ 占位符&#xff08;Property Placeholder&#xff09; 1. 作用 从配置文件&#xff08;如 application.propertie…...

在 RK3588 上通过 VSCode 远程开发配置指南

在 RK3588 上通过 VSCode 远程开发配置指南 RK3588 设备本身不具备可视化编程环境&#xff0c;但可以通过 VSCode 的 Remote - SSH 插件 实现远程代码编写与调试。以下是完整的配置流程。 一、连接 RK3588 1. 安装 Debian 系统 先在 RK3588 上安装 Debian 操作系统。 2. 安…...

OpenHarmony标准系统-HDF框架之音频驱动开发

文章目录 引言OpenHarmony音频概述OpenHarmony音频框图HDF音频驱动框架概述HDF音频驱动框图HDF音频驱动框架分析之音频设备驱动HDF音频驱动框架分析之supportlibs实现HDF音频驱动框架分析之hdi-passthrough实现HDF音频驱动框架分析之hdi-bindev实现HDF音频驱动加载过程HDF音频驱…...

HTML Day03

Day03 0. 引言1. CSS1.1 CSS的3种使用方法1.2 内联样式1.3 内部样式表1.4 外部CSS文件 2. 图像3. 表格3.1单元格间距和单元格边框 4. 列表4.1 有序表格的不同类型4.2 不同类型的无序表格4.3 嵌套列表 5. 区块6. 布局6.1 div布局6.2 表格布局 0. 引言 HELLO ^ _ ^大家好&#xf…...

篇章六 数据结构——链表(二)

目录 1. LinkedList的模拟实现 1.1 双向链表结构图​编辑 1.2 三个简单方法的实现 1.3 头插法 1.4 尾插法 1.5 中间插入 1.6 删除 key 1.7 删除所有key 1.8 clear 2.LinkedList的使用 2.1 什么是LinkedList 5.2 LinkedList的使用 1.LinkedList的构造 2. LinkedList的…...

Python60日基础学习打卡Day39

昨天我们介绍了图像数据的格式以及模型定义的过程&#xff0c;发现和之前结构化数据的略有不同&#xff0c;主要差异体现在2处 模型定义的时候需要展平图像由于数据过大&#xff0c;需要将数据集进行分批次处理&#xff0c;这往往涉及到了dataset和dataloader来规范代码的组织…...

吴恩达MCP课程(3):mcp_chatbot

原课程代码是用Anthropic写的&#xff0c;下面代码是用OpenAI改写的&#xff0c;模型则用阿里巴巴的模型做测试 .env 文件为&#xff1a; OPENAI_API_KEYsk-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx OPENAI_API_BASEhttps://dashscope.aliyuncs.com/compatible-mode…...