Sql事务

本文详细介绍了事务的ACID属性,并通过创建存储过程实现了转账操作的细节,包括判断账号是否存在、转账金额是否合理以及进行转账的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  事务有4个属性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)以及持久性(Durability),也称作事务的ACID属性。

创建表 加入数据

CREATE TABLE Money

(
ID int NOT NULL PRIMARY KEY,
moneys money NULL
)
SELECT * FROM money
INSERT INTO money VALUES(1,2000),

(2,3000)


创建存储过程 使用存储过程完成事务


CREATE PROC pro_money(
@toID int , --转入账号
@fromID int,--转出账号
@Momery money)--转账金额
AS
--判断账号是否存在
IF EXISTS(SELECT 1 FROM money WHERE id=@fromID)
BEGIN
IF EXISTS(SELECT 1 FROM money WHERE id=@toID)
BEGIN
--判断转出金额是否大于当前余额
IF(SELECT moneys FROM money WHERE id=@fromID)>=@Momery
BEGIN
--开始 事务
BEGIN TRAN
UPDATE money SET moneys-=@Momery WHERE id=@fromID
UPDATE money SET moneys+=@Momery WHERE id=@toID
IF @@ERROR<>0
BEGIN
ROLLBACK TRAN --回滚
  PRINT '失败'
END 
  ELSE
BEGIN
  COMMIT TRAN --提交事务
PRINT '成功'
END


END
ELSE
RAISERROR('转账金额大于余额',16,1)   raiserror 是用于抛出一个错误
END
ELSE
RAISERROR('转出账号不存在',16,1)
END
ELSE
RAISERROR('转出账号不存在',16,1)




EXEC pro_money 2,3,1  --执行查询结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

费劲_奋进

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值