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

myslql事务示例

在 MySQL 中,事务(Transaction)是一组要么全部执行,要么全部不执行的SQL语句。这可以确保数据的一致性和完整性。事务管理的核心包括四个属性,即原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability),通常简称为ACID属性。

示例:使用事务管理

假设我们有两个账户表 accounts,每个账户有一个唯一的ID和一个余额。我们将展示如何在两个账户之间进行资金转移,并确保这个操作是原子性的。

创建示例表并插入数据
CREATE TABLE accounts (account_id INT PRIMARY KEY,balance DECIMAL(10, 2)
);INSERT INTO accounts (account_id, balance) VALUES
(1, 1000.00),
(2, 2000.00);
使用事务进行资金转移

下面是一个示例,展示了如何在 MySQL 中使用事务进行账户之间的资金转移。

START TRANSACTION;-- 从账户1中扣款
UPDATE accounts
SET balance = balance - 100
WHERE account_id = 1;-- 向账户2中存款
UPDATE accounts
SET balance = balance + 100
WHERE account_id = 2;-- 检查账户1的余额是否不足以扣款
SELECT balance INTO @balance FROM accounts WHERE account_id = 1;
IF @balance < 0 THEN-- 如果余额不足,回滚事务ROLLBACK;SELECT 'Transaction failed: insufficient funds' AS message;
ELSE-- 如果余额充足,提交事务COMMIT;SELECT 'Transaction succeeded' AS message;
END IF;

解释

  1. START TRANSACTION:开始一个事务。
  2. UPDATE 语句:执行两次更新操作,分别从账户1中扣款并向账户2中存款。
  3. SELECT INTO 语句:检查账户1的余额是否不足以扣款。
  4. IF 语句:如果账户1的余额不足,回滚事务;否则,提交事务。
  5. ROLLBACK:如果余额不足,则回滚事务,取消所有先前执行的操作。
  6. COMMIT:如果余额充足,则提交事务,保存所有更改。

详细步骤

  1. 开始事务

    START TRANSACTION;
    

    开始一个新的事务块。

  2. 执行更新操作

    UPDATE accounts
    SET balance = balance - 100
    WHERE account_id = 1;UPDATE accounts
    SET balance = balance + 100
    WHERE account_id = 2;
    
  3. 检查余额

    SELECT balance INTO @balance FROM accounts WHERE account_id = 1;
    IF @balance < 0 THEN-- 如果余额不足,回滚事务ROLLBACK;SELECT 'Transaction failed: insufficient funds' AS message;
    ELSE-- 如果余额充足,提交事务COMMIT;SELECT 'Transaction succeeded' AS message;
    END IF;
    

使用存储过程实现事务

将上述操作封装在存储过程中,更加清晰和模块化:

DELIMITER $$CREATE PROCEDURE transfer_funds(IN p_from_account_id INT,IN p_to_account_id INT,IN p_amount DECIMAL(10, 2)
)
BEGINDECLARE balance DECIMAL(10, 2);START TRANSACTION;-- 从源账户扣款UPDATE accountsSET balance = balance - p_amountWHERE account_id = p_from_account_id;-- 向目标账户存款UPDATE accountsSET balance = balance + p_amountWHERE account_id = p_to_account_id;-- 检查源账户余额是否充足SELECT balance INTO balance FROM accounts WHERE account_id = p_from_account_id;IF balance < 0 THEN-- 如果余额不足,回滚事务ROLLBACK;SELECT 'Transaction failed: insufficient funds' AS message;ELSE-- 如果余额充足,提交事务COMMIT;SELECT 'Transaction succeeded' AS message;END IF;
END$$DELIMITER ;

调用存储过程:

CALL transfer_funds(1, 2, 100.00);

总结

  • 开始事务:使用 START TRANSACTION
  • 提交事务:使用 COMMIT
  • 回滚事务:使用 ROLLBACK

通过这些步骤,可以在 MySQL 中管理事务,确保数据一致性和完整性。

http://www.lryc.cn/news/378420.html

相关文章:

  • 解决Flutter应用程序的兼容性问题
  • 整合微信支付一篇就够了
  • 视创云展为企业虚拟展厅搭建,提供哪些功能?
  • c++ 常用的锁及用法介绍和示例
  • PostgreSQL源码分析——口令认证
  • Stability-AI(图片生成视频)
  • Linux机器通过Docker-Compose安装Jenkins发送Allure报告
  • 基于Gunicorn+Flask+Docker模型高并发部署
  • java:类型变量(TypeVariable)解析--基于TypeResolver实现将类型变量替换为实际类型
  • ru俄罗斯域名如何申请SSL证书?
  • python实现购物车的功能
  • 日元预计明年开始上涨
  • 8、PHP 实现二进制中1的个数、数值的整数次方
  • linux git凭证管理
  • WIC 图像处理初体验——读取像素的值
  • 使用Server-Sent Events (SSE),并获取message里面的内容
  • LabVIEW项目管理中如何平衡成本、时间和质量
  • 如何检查 Kubernetes 网络配置
  • 如何将网站封装成App:小猪APP分发助你实现
  • 探索C嘎嘎的奇妙世界:第十六关---STL(vector的练习)
  • 最新扣子(Coze)实战案例:扣子卡片的制作及使用,完全免费教程
  • Node-red win11安装
  • 永久更改R包的安装目录
  • Webrtc支持FFMPEG硬解码之NVIDA(二)
  • 整理好了!2024年最常见 20 道设计模式面试题(九)
  • RAG实操教程langchain+Milvus向量数据库创建你的本地知识库 二
  • Spring+SpringMVC介绍+bean实例化+依赖注入实战
  • 【安装笔记-20240616-Linux-为 OpenWrt 自动挂载 Windows 主机共享目录】
  • 61.WEB渗透测试-信息收集- WAF、框架组件识别(1)
  • qmt量化交易策略小白学习笔记第45期【qmt编程之期货行情数据--如何获取日线行情、tick行情】