浅谈Sql Server 事务

一、基本介绍

        SQL Server 中,事务是一组原子性的 SQL 操作集合,这意味着这些操作要么全部成功,要么全部失败。事务确保数据库在面对多个操作时保持一致性和完整性。

二、事务的特性

事务的特性

事务具有所谓的 ACID 属性,即:

  1. 原子性(Atomicity):事务中的所有操作要么全部完成,要么全部不完成。
  2. 一致性(Consistency):事务必须确保数据库从一个一致的状态转换到另一个一致的状态。
  3. 隔离性(Isolation):并发执行的事务之间相互隔离,不受其他事务的干扰。
  4. 持久性(Durability):一旦事务提交,它对数据库的修改就是永久性的,即使系统发生故障也不会丢失

三、事务的控制语句

在 SQL Server 中,可以使用以下 T-SQL 语句来控制事务:

  • BEGIN TRANSACTION 或 BEGIN TRAN:开始一个新的事务。
  • COMMIT TRANSACTION 或 COMMIT TRAN:提交当前事务,使所有更改永久生效。
  • ROLLBACK TRANSACTION 或 ROLLBACK TRAN:回滚当前事务,撤销自事务开始以来所做的所有更改。
  • SAVE TRANSACTION <savepoint_name>:在事务中创建一个保存点,可以回滚到此点。

四、事务的使用示例

以下是一个简单的事务示例,其中包含了两个操作:向账户扣除金额和向另一个账户添加金额。

BEGIN TRANSACTION;
BEGIN TRY-- 尝试从账户 1 扣除 100 单位的货币UPDATE Accounts SET Balance = Balance - 100 WHERE AccountID = 1;-- 尝试向账户 2 增加 100 单位的货币UPDATE Accounts SET Balance = Balance + 100 WHERE AccountID = 2;-- 如果没有错误发生,则提交事务COMMIT TRANSACTION;
END TRY
BEGIN CATCH-- 如果发生错误,则回滚事务ROLLBACK TRANSACTION;-- 可以在这里处理错误,例如记录错误日志
END CATCH

嵌套事务

SQL Server 支持嵌套事务,可以使用 SAVE TRANSACTION 来创建保存点,并使用 ROLLBACK TRANSACTION 回滚到保存点。

BEGIN TRANSACTION;
BEGIN TRY-- 执行一些操作UPDATE Accounts SET Balance = Balance - 100 WHERE AccountID = 1;SAVE TRANSACTION PointA;-- 执行更多操作UPDATE Accounts SET Balance = Balance + 100 WHERE AccountID = 2;-- 如果一切正常,则提交事务COMMIT TRANSACTION;
END TRY
BEGIN CATCH-- 如果发生错误,则回滚到保存点ROLLBACK TRANSACTION PointA;-- 可以在这里处理错误
END CATCH

五、注意事项

  • 事务应在尽可能短的时间段内完成,以减少锁定资源的时间。
  • 在事务中,所有操作都是临时的,直到事务被提交。
  • 事务可能会影响数据库的性能,特别是在高并发的环境中,因此应该谨慎使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/145417.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

C++—string类接口与用法大总结(其中涉及STL基础)

目录 1.string类的本质 2.string类的构造 1.普通构造 2.功能型构造 1.拷贝构造功能型 2.带参构造功能型 3.其余构造 3.operator[] 4.迭代器&#xff08;iterator&#xff09; 1.概念 2.改变string对象本身 3.正向迭代器&#xff08;iterator&#xff09; 4.反向迭代…

BLE 协议之链路层

目录 一、前言二、状态和角色三、Air Interface Packets1、Preamble 字段2、Access Address 字段2.1 静态地址2.2 私有地址 3、PDU 字段3.1 Advertising Channel PDU3.1.1 Header 字段3.1.2 Payload 字段 3.2 Data Channel PDU3.2.1 Header 字段3.2.2 Payload 字段 4、CRC 字段…

YOLO交通目标识别数据集(红绿灯-汽车-自行车-卡车等)

YOLO交通目标识别 数据集 模型 ui界面 ✓图片数量15000&#xff0c;xml和txt标签都有&#xff1b; ✓class&#xff1a;biker&#xff0c;car&#xff0c;pedestrian&#xff0c;trafficLight&#xff0c;trafficLight-Green&#xff0c;trafficLight-GreenLeft&#xff0c; t…

OpenCV特征检测(3)计算图像中每个像素处的特征值和特征向量函数cornerEigenValsAndVecs()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 计算图像块的特征值和特征向量用于角点检测。 对于每一个像素 p &#xff0c;函数 cornerEigenValsAndVecs 考虑一个 blockSize blockSize 的邻…

Ferret-UI——于移动用户界面的多模态大规模语言模型

概述 论文地址&#xff1a;https://arxiv.org/abs/2404.05719 移动应用程序已成为我们日常生活中不可或缺的工具&#xff0c;涉及信息搜索、预订和娱乐等多个领域。我们通常会目测屏幕&#xff0c;然后根据自己的目的执行必要的操作。将这一过程自动化可以让用户更轻松地实现…

【秋招笔试-支持在线评测-试读版】9.19小米秋招(已改编)-三语言题解

&#x1f36d; 大家好这里是 春秋招笔试突围&#xff0c;一起备战大厂笔试 &#x1f4bb; ACM金牌团队&#x1f3c5;️ | 多次AK大厂笔试 &#xff5c; 大厂实习经历 ✨ 本系列打算持续跟新 春秋招笔试题 &#x1f44f; 感谢大家的订阅➕ 和 喜欢&#x1f497; 和 手里的小花花…

阿贝云评测:免费虚拟主机和免费云服务器体验分享

最近我有幸体验了阿贝云提供的免费虚拟主机和免费云服务器&#xff0c;在这里分享一下我的使用体验。首先我想说的是&#xff0c;阿贝云的服务真的很不错。他们提供的免费虚拟主机性能稳定&#xff0c;速度快&#xff0c;对于刚开始建站的小伙伴来说是一个很好的选择。免费云服…

阿里发布史上最大规模开源全家桶!千问2.5系列发布

实话说&#xff0c;我一直没想明白阿里为什么会在大模型这个赛道&#xff0c;成为中国版的Meta。 扎克伯格被问及为什么要做开源大模型时说&#xff0c;“我们的商业模式并不是靠卖模型赚钱“。显然&#xff0c;Meta没有云平台产品&#xff0c;就算要卖模型赚钱&#xff0c;效…

前端vue-单选按钮的实现

要把name“sex”和value"男" 和 要把name“sex”和value"女"写上&#xff0c;然后在各自的标签内部写上v-model绑定属性。data中定义v-model的绑定值&#xff0c;后面的值是默认选中的男或者女性。

B站前端错误监控实践

前言 从23年开始&#xff0c;我们团队开始前端错误监控方向的开发。经历了一些列的迭代和发展&#xff0c;从监控SDK、上报、数据治理、看板集成、APM自研可视化初步完成了一条完整且适合B站前端监控。 截止目前(2024.08.01)&#xff0c;前端监控在B站85%以上的业务线&#xf…

Percona发布开源DBaaS平台;阿里云RDS发布全球多活数据库(GAD);Redshift支持自然语言生成SQL

重要更新 1. 云栖大会于本周四/五在杭州举行&#xff0c;周五上午云栖主论坛阿里云数据库负责人李飞飞将发表《从数据到智能&#xff1a;DataAI驱动的云原生数据库》演讲&#xff0c;另外&#xff0c;还有多场次的数据库专场&#xff0c;感兴趣的可以现场或在线观看&#xff1a…

前端vue-自己封装组件并使用三步走

在components下&#xff0c;创建.vue文件&#xff0c;里面正常写样式什么的&#xff0c;在需要引用的文件内先在script标签内引入在components下创建的组件&#xff0c;再导出处使用&#xff0c;再在templete标签内直接使用自己封装的组件。

SQL - 基础语法

SQL作为一种操作命令集, 以其丰富的功能受到业内人士的广泛欢迎, 成为提升数据库操作效率的保障。SQL Server数据库的应用&#xff0c;能够有效提升数据请求与返回的速度&#xff0c;有效应对复杂任务的处理&#xff0c;是提升工作效率的关键。 由于SQL Servers数据库管理系统…

【学术会议:中国杭州,机器学习和计算机应用面临的新的挑战问题和研究方向】第五届机器学习与计算机应用国际学术会议(ICMLCA 2024)

您的学术研究值得被更多人看到&#xff01; 在这里&#xff0c;我为您提供精准的会议推荐&#xff0c;包括水利土木工程、计算机科学、地球科学、机械自动化、材料与制造技术、经管金融、人文社科等主流学科相关领域的国际会议。快速的稿件录用和高效的检索服务将确保您的研究…

平价头戴式蓝牙耳机有哪些?四款公认平价性能超强品牌机型推荐

在追求高品质音乐体验的同时&#xff0c;许多消费者希望找到价格亲民的头戴式蓝牙耳机&#xff0c;市场上不乏性能卓越、价格实惠的产品&#xff0c;它们凭借出色的音质、舒适的佩戴体验和可靠的续航能力赢得了用户的青睐&#xff0c;那么在众多的头戴式蓝牙耳机内&#xff0c;…

Android 空气质量刻度

效果 attrs.xml <attr name"textSpace" format"dimension|reference" /><attr name"barSpace" format"dimension|reference" /><attr name"scaleHeight" format"dimension|reference" /><at…

在 Windows 上运行 Vue 项目时解决 ‘NODE_OPTIONS‘ 错误

在 Windows 上运行 Vue 项目时解决 ‘NODE_OPTIONS’ 错误 在 Windows 系统上启动 Vue 项目时&#xff0c;遭遇报错。具体报错信息如下&#xff1a; ‘NODE_OPTIONS‘ 不是内部或外部命令&#xff0c;也不是可运行的程序或批处理文件。这个错误通常意味着 Windows 系统无法识…

SimpleAISearch:C# + DuckDuckGo 实现简单的AI搜索

最近AI搜索很火爆&#xff0c;有Perplexity、秘塔AI、MindSearch、Perplexica、memfree、khoj等等。 在使用大语言模型的过程中&#xff0c;或许你也遇到了这种局限&#xff0c;就是无法获取网上最新的信息&#xff0c;导致回答的内容不是基于最新的信息&#xff0c;为了解决这…

企业微信redirect_uri 与配置的授权完成回调域名不一致

这有几个前提 你先排除下 1、第三方方应用的使用配置里&#xff0c;这一排域名&#xff0c;一定要和你的回调域名一致 2、官方的设置授权配置里》 https://developer.work.weixin.qq.com/document/path/90602 在你还没上线的第三方应用前&#xff01;&#xff01;&#xff0…

FreeRTOS(三)FreeRTOS任务挂起和恢复与中断

在 FreeRTOS 中&#xff0c;任务挂起&#xff08;Suspend&#xff09;和恢复&#xff08;Resume&#xff09;是用于控制任务执行流程的两个重要操作。挂起一个任务会使其暂停执行&#xff0c;而恢复一个任务则使其重新进入调度器的考虑范围&#xff0c;可能在适当的时候被调度执…