SQL SERVER TRANSACTION 事物
2024-08-25 22:35:13
1.事务的概念
事物是一种机制,是一种操作序列,它包含了数据库一组操作命令,这组命令要么全部执行,要么都不执行。因此事物是一组不可分割的事物逻辑单元,在数据库进行并发操作时候,事物是作为最小的控制单元来使用的,这特别适用于多用户同时操作的数据通信系统。例如:订票、银行、保险公司以及证券交易系统等。
2.事物的4大属性
- 原子性:事物是一个完整的操作;
- 隔离性:对数据进行修改的所有并发事物都是彼此隔离的;
- 一致性:当事物完成时,事物必须处于一致的状态;
- 持久性:事物完成后,对于系统的影响是永久的;
3.创建事物
- 开始事物:transaction begin
- 提交事物:commit transaction
- 回滚事物:rollback transaction
4.事物的分类
- 显示事物:用begin transaction 明确指定事物的开始,用commit transaction, rollback transaction来结束或者回滚事务
- 隐示事物(自动提交事物):隐式事务则在执完语句后自动提交事务
5.事例
实现转账操作,转账人出账和收账人入账是一组完整的操作序列,必须全部完成或不完成,准备一张用户钱包表(tbUserWallet),转账交易记录表(tbTransaction),简单设计如下
向用户钱包表(tbUserWallet)添加测试数据
创建转账存储事物
USE [TEST]
GO /****** Object: StoredProcedure [dbo].[pAddTransaction] Script Date: 2018/5/21 12:44:59 ******/
SET ANSI_NULLS ON
GO SET QUOTED_IDENTIFIER ON
GO -- =============================================
-- Author: yangyi
-- Create date: 18/05/21
-- Description: 转账
-- =============================================
CREATE PROCEDURE [dbo].[pAddTransaction]
@InOpenID uniqueidentifier,
@InTDesc nvarchar(50),
@OutOpenID uniqueidentifier,
@OutTDesc nvarchar(50),
@TAmount decimal(10, 2),
@TTID int,
@Result int output
AS
BEGIN
IF((SELECT Amount FROM tbUserWallet WHERE OpenID=@OutOpenID)>=@TAmount)
BEGIN
BEGIN TRANSACTION
BEGIN TRY
UPDATE tbUserWallet SET Amount=Amount-@TAmount WHERE OpenID=@OutOpenID
UPDATE tbUserWallet SET Amount=Amount+@TAmount WHERE OpenID=@InOpenID
--SELECT 1+'A'
INSERT INTO [dbo].[tbTransaction]([TID],[OpenID],[TAmount],[TTID],[TDesc],[CreateDT])VALUES(NEWID(),@InOpenID,@TAmount,@TTID,@InTDesc,GETDATE())
INSERT INTO [dbo].[tbTransaction]([TID],[OpenID],[TAmount],[TTID],[TDesc],[CreateDT])VALUES(NEWID(),@OutOpenID,-@TAmount,@TTID,@OutTDesc,GETDATE())
END TRY
BEGIN CATCH
IF(@@TRANCOUNT>0)
BEGIN
SET @Result=-1
PRINT '事物执行出错,回滚'
ROLLBACK TRANSACTION
END
END CATCH
IF(@@TRANCOUNT>0)
BEGIN
SET @Result=1
PRINT '一切按预期计划执行'
COMMIT TRANSACTION
END
END
ELSE
BEGIN
PRINT '转账人金额不足'
SET @Result=0
END
END GO
测试1>:转账人金额不足测试
USE [TEST]
GO DECLARE @return_value int,
@Result int EXEC @return_value = [dbo].[pAddTransaction]
@InOpenID = '1ccd524d-de62-47ca-87d3-38787b040ba3',
@InTDesc = N'收到A的转账100',
@OutOpenID = '2ccd524d-de62-47ca-87d3-38787b040ba3',
@OutTDesc = N'转账给A100',
@TAmount = 100,
@TTID = 1,
@Result = @Result OUTPUT SELECT @Result as N'@Result' GO
测试2>:模拟事物出现错误,进行回滚
取消存储事物中的:SELECT 1+'A' 注释(模拟事物中发生错误)
USE [TEST]
GO DECLARE @return_value int,
@Result int EXEC @return_value = [dbo].[pAddTransaction]
@InOpenID = '2ccd524d-de62-47ca-87d3-38787b040ba3',
@InTDesc = N'收到A的转账100',
@OutOpenID = '1ccd524d-de62-47ca-87d3-38787b040ba3',
@OutTDesc = N'转账给A100',
@TAmount = 100,
@TTID = 1,
@Result = @Result OUTPUT SELECT @Result as N'@Result' GO
测试3.>执行成功测试,注释 SELECT 1+'A'
USE [TEST]
GO DECLARE @return_value int,
@Result int EXEC @return_value = [dbo].[pAddTransaction]
@InOpenID = '2ccd524d-de62-47ca-87d3-38787b040ba3',
@InTDesc = N'收到A的转账100',
@OutOpenID = '1ccd524d-de62-47ca-87d3-38787b040ba3',
@OutTDesc = N'转账给A100',
@TAmount = 100,
@TTID = 1,
@Result = @Result OUTPUT SELECT @Result as N'@Result' GO
最新文章
- 【深入】java 单例模式(转)
- UIbutton 圆角和边线
- POJ 3177 Redundant Paths POJ 3352 Road Construction
- unity3d游戏无法部署到windows phone8手机上的解决方法
- 转载:Python中的new style class机制实现
- iOS开发富文本
- 设计模式之单一职责原则(SRP)
- Matlab将三维变量分割为多个二维变量的方法
- Oracle12c多租户CDB 与 PDB 参数文件位置探讨、查询 CDB 与 PDB 不同值的参数
- C语言结构体定义的几种方法
- 前后端分离djangorestframework——解决跨域请求
- Jenkins - Extended E-mail配置教程
- bootstrap 弹窗或者提示框插件 bootstrap-growl 和bootstrap-notify
- 使用docker安装tomcat服务
- 第二个spring
- 使用Let's Encrypted HPPTS你的网站
- Android 搭建ssh服务
- electron-vue 开发环境搭建(Windows环境)
- 4 个用于构建优秀的命令行用户界面的 Python 库
- iOS 一些常见问题
热门文章
- Ubuntu 安装Sqldeveloper
- .Net Core Web应用发布至IIS后报“An error occurred while starting the application”错误
- ServiceStack NetCoreAppSettings 配置文件读取和设置
- 数据导出之winfrom导出word(二)
- 定位 和 z-index
- cad2020卸载/安装失败/如何彻底卸载清除干净cad2020注册表和文件的方法
- jQuery的ajax的post请求json格式无法上传空数组
- Caffe 使用记录(一)mnist手写数字识别
- Redis 入门知识
- 判断一个类是否为另一个类的实例 instanceof关键字和isAssignableFrom方法的区别