SQL Server 中的事务是什么
发布时间:2023-12-23 05:58:32 所属栏目:MsSql教程 来源:DaWei
导读: SQL Server 中的事务是一组被视为一个单元的 SQL 语句,它们按照“做所有事或不做任何事”的原则执行,成功的事务必须通过 ACID 测试。
事务的 ACID 属性是什么?
首字母缩写
事务的 ACID 属性是什么?
首字母缩写
|
SQL Server 中的事务是一组被视为一个单元的 SQL 语句,它们按照“做所有事或不做任何事”的原则执行,成功的事务必须通过 ACID 测试。 事务的 ACID 属性是什么? 首字母缩写词 ACID 是指事务的四个关键属性 原子性: Atomicity 一致性: Consistency 隔离性: Isolation 持久性: Durability 为了理解这一点,我们将使用以下两个表测试。 Product (产品表) ProductID Name Price Quantity 101 Laptop 15000 100 102 Desktop 20000 150 104 Mobile 3000 200 105 Tablet 4000 250 ProductSales (产品销售表) ProductSalesID ProductID QuantitySold 1 101 10 2 102 15 3 104 30 4 105 35 请使用以下 SQL 脚本创建并使用示例数据填充 Product 和 ProductSales 表。 IF OBJECT_ID('dbo.Product','U') IS NOT NULL DROP TABLE dbo.Product IF OBJECT_ID('dbo.ProductSales','U') IS NOT NULL DROP TABLE dbo.ProductSales GO CREATE TABLE Product ( ProductID INT PRIMARY KEY, Name VARCHAR(40), Price INT, Quantity INT ) GO INSERT INTO Product VALUES(101, 'Laptop', 15000, 100) INSERT INTO Product VALUES(102, 'Desktop', 20000, 150) INSERT INTO Product VALUES(103, 'Mobile', 3000, 200) INSERT INTO Product VALUES(104, 'Tablet', 4000, 250) GO CREATE TABLE ProductSales ( ProductSalesId INT PRIMARY KEY, ProductId INT, QuantitySold INT ) GO INSERT INTO ProductSales VALUES(1, 101, 10) INSERT INTO ProductSales VALUES(2, 102, 15) INSERT INTO ProductSales VALUES(3, 103, 30) INSERT INTO ProductSales VALUES(4, 104, 35) GO SQL Server 中事务的原子性 SQL Server 中事务的原子性确保事务中的所有 DML 语句(即插入、更新、删除)成功完成或全部回滚。例如,在以下 spSellProduct 存储过程中,UPDATE 和 INSERT 语句都应该成功。如果 UPDATE 语句成功而 INSERT 语句失败,数据库应该通过回滚来撤消 UPDATE 语句所做的更改。 IF OBJECT_ID('spSellProduct','P') IS NOT NULL DROP PROCEDURE spSellProduct GO CREATE PROCEDURE spSellProduct @ProductID INT, @QuantityToSell INT AS BEGIN -- 首先我们需要检查待销售产品的可用库存 DECLARE @StockAvailable INT SELECT @StockAvailable = Quantity FROM Product WHERE ProductId = @ProductId --如果可用库存小于要销售的数量,抛出错误 IF(@StockAvailable < @QuantityToSell) BEGIN Raiserror('可用库存不足',16,1) END -- 如果可用库存充足 ELSE BEGIN BEGIN TRY -- 我们需要开启一个事务 BEGIN TRANSACTION -- 首先做减库存操作 UPDATE Product SET Quantity = (Quantity - @QuantityToSell) WHERE ProductID = @ProductID -- 计算当前最大的产品销售ID,即 MaxProductSalesId DECLARE @MaxProductSalesId INT SELECT @MaxProductSalesId = CASE WHEN MAX(ProductSalesId) IS NULL THEN 0 ELSE MAX(ProductSalesId) END FROM ProductSales -- 把 @MaxProductSalesId 加一, 所以我们会避免主键冲突 --(解释下,建表的时候,没有设置主键自增,所以需要人工处理自增) Set @MaxProductSalesId = @MaxProductSalesId + 1 -- 把销售的产品数量记录到ProductSales表中 INSERT INTO ProductSales VALUES (@MaxProductSalesId, @ProductId, @QuantityToSell) -- 最后,提交事务 COMMIT TRANSACTION END TRY BEGIN CATCH -- 如果发生了异常,回滚事务 ROLLBACK TRANSACTION END CATCH End END (编辑:天瑞地安资讯网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- SQL Server数据库降级工具
- sql-server – 总是有一个整数列作为主键的缺点是什么?
- 学数据库这么久了,必须要掌握的MySQL常用语句,安排
- C语言循环结构(while循环,for循环,do…while循环)
- MSSQL 2014数据库Alwayson下日志过大,压缩日志的处理方法
- 将EventLog Analyzer数据从MySQL迁移到MSSQL数据库
- sql-server – CPU时钟速度与CPU核心数量 – 更高的GHz,或更
- 【MySQL】左连接右连接内连接与Hash连接、子查询原理与实战
- 推荐一款 MySQL 开源客户端,免费 + 跨平台 + 使用便捷!
- jwt – Keycloak从数据库/外部源添加额外声明
推荐文章
站长推荐
