当前位置: 首页 > 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 中管理事务,确保数据一致性和完整性。

相关文章:

myslql事务示例

在 MySQL 中&#xff0c;事务&#xff08;Transaction&#xff09;是一组要么全部执行&#xff0c;要么全部不执行的SQL语句。这可以确保数据的一致性和完整性。事务管理的核心包括四个属性&#xff0c;即原子性&#xff08;Atomicity&#xff09;、一致性&#xff08;Consiste…...

解决Flutter应用程序的兼容性问题

哈喽呀&#xff0c;大家好呀&#xff0c;淼淼又来和大家见面啦&#xff0c;Flutter作为一个跨平台的移动应用开发框架&#xff0c;极大地简化了开发者同时在Android和iOS平台上构建应用的难度。然而&#xff0c;由于不同设备、操作系统版本以及Flutter框架本身的变化&#xff0…...

整合微信支付一篇就够了

需要的工具 微信开发小程序工具 需要的材料 关键步骤 postman获取微信access_token https://api.weixin.qq.com/cgi-bin/token?appid=wxfssafa629021&grant_type=client_credential&secret=701d213dsfsdfsfdss4fb274生成h5跳转小程序的链接 https://api.weixin.…...

视创云展为企业虚拟展厅搭建,提供哪些功能?

在当下数字化浪潮中&#xff0c;如何为用户创造更富生动性和真实感的展示体验&#xff0c;已成为企业营销策略的核心。借助视创云展的线上虚拟3D企业展厅搭建服务&#xff0c;利用3D空间漫游和VR技术的融合&#xff0c;可以为用户呈现出一个既真实又充满想象力的全景图或三维模…...

c++ 常用的锁及用法介绍和示例

2024/6/21 14:20:10 在 C++ 中,常用的锁主要包括以下几种:std::mutex、std::recursive_mutex、std::timed_mutex 和 std::shared_mutex。这些锁可以帮助我们在多线程编程中保护共享数据,避免竞争条件。以下是每种锁的介绍及其用法示例: std::mutex std::mutex 是最基本的互…...

PostgreSQL源码分析——口令认证

认证机制 对于数据库系统来说&#xff0c;其作为服务端&#xff0c;接受来自客户端的请求。对此&#xff0c;必须有对客户端的认证机制&#xff0c;只有通过身份认证的客户端才可以访问数据库资源&#xff0c;防止非法用户连接数据库。PostgreSQL支持认证方法有很多&#xff1…...

Stability-AI(图片生成视频)

1.项目地址 GitHub - Stability-AI/generative-models: Generative Models by Stability AI 2.模型地址 魔搭社区 3.克隆项目后&#xff0c;按照教程安装 conda create --name Stability python3.10 conda activate Stability pip3 install -r requirements/pt2.txt py…...

Linux机器通过Docker-Compose安装Jenkins发送Allure报告

目录 一、安装Docker 二、安装Docker Compose 三、准备测试用例 四、配置docker-compose.yml 五、启动Jenkins 六、配置Jenkins和Allure插件 七、创建含pytest的Jenkins任务 八、项目结果通知 1.通过企业微信通知 2.通过邮件通知 九、配置域名DNS解析 最近小编接到一…...

基于Gunicorn+Flask+Docker模型高并发部署

关于猫头虎 大家好&#xff0c;我是猫头虎&#xff0c;别名猫头虎博主&#xff0c;擅长的技术领域包括云原生、前端、后端、运维和AI。我的博客主要分享技术教程、bug解决思路、开发工具教程、前沿科技资讯、产品评测图文、产品使用体验图文、产品优点推广文稿、产品横测对比文…...

java:类型变量(TypeVariable)解析--基于TypeResolver实现将类型变量替换为实际类型

上一篇博客《java:类型变量(TypeVariable)解析–获取泛型类(Generic Class)所有的类型变量(TypeVariable)的实际映射类型》中介绍如何如何正确解析泛型类的类型变量(TypeVariable)&#xff0c;获取对应的实际类型。 有了类型变量(TypeVariable)–实际类型的映射&#xff0c;我们…...

ru俄罗斯域名如何申请SSL证书?

我们日常看到的都是com这种国际域名比较普遍&#xff0c;尤其是主流网站&#xff0c;主要原因考虑的其通用性&#xff0c;那么对于地方性的域名大家很少看到&#xff0c;比如俄罗斯国家域名.ru大家还是有些陌生的&#xff0c;但要说中国.CN域名那你就很熟悉了。 有用户在申请过…...

python实现购物车的功能

模拟购物车&#xff0c;准备一个列表 goodList [{name:笔记本电脑,price:8000}, {name:鼠标, price:100}] 5个函数 1.加入购物车 2.收藏商品 3.去结算 4.删除购物车商品 5.清空购物车 购物车 cartList [] 收藏列表 collectSet {笔记本电脑,鼠标} 数据示例 去结算计算出总价…...

日元预计明年开始上涨

被称为“日元先生”的前大藏省&#xff08;现财务省&#xff09;财务官榊原英资预测&#xff0c;美元兑日元汇率将在今年底或2025年初逐步升至130。他认为&#xff0c;通缩时代已经过去&#xff0c;通货膨胀即将来临。 《日本经济新闻》6月5日报道&#xff0c;日本财务省于5月3…...

8、PHP 实现二进制中1的个数、数值的整数次方

题目&#xff1a; 二进制中1的个数 描述&#xff1a; 输入一个整数&#xff0c;输出该数二进制表示中1的个数。其中负数用补码表示。 <?phpfunction NumberOf1($n) {$count 0;if($n < 0){$n $n & 0x7FFFFFFF;$count;}while($n ! 0){$count;$n $n & ($n - 1…...

linux git凭证管理

linux git 凭证管理 解决命令行git登录github的问题&#xff0c;支持两步验证 同样适用于Azure Devops, Bitbucket 官网&#xff1a; https://github.com/git-ecosystem/git-credential-manager https://github.com/git-ecosystem/git-credential-manager/blob/release/docs/…...

WIC 图像处理初体验——读取像素的值

先放上运行结果&#xff1a; 可以发现红绿蓝是从后往前的。 必须以C方式编译代码&#xff01; #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <wincodec.h>int main(void) {CoInitialize(nullptr);IWICImagingFactory* fac;CoCreateInstance(CLS…...

使用Server-Sent Events (SSE),并获取message里面的内容

什么是Server-Sent Events (SSE)? Server-Sent Events (SSE)是一种服务器推送技术&#xff0c;允许服务器向客户端&#xff08;浏览器&#xff09;发送实时消息。与WebSocket不同&#xff0c;SSE是单向通信&#xff0c;只能从服务器到客户端。SSE在HTML5中作为标准实现&#…...

LabVIEW项目管理中如何平衡成本、时间和质量

在LabVIEW项目管理中&#xff0c;平衡成本、时间和质量是实现项目成功的关键。通过制定详细的项目计划、合理分配资源、严格控制进度、进行质量保证和灵活应对变化&#xff0c;项目管理者可以有效地协调这三者的关系&#xff0c;确保项目按时、按质、按预算完成。 1. 制定详细…...

如何检查 Kubernetes 网络配置

简介 Kubernetes 是一个容器编排系统&#xff0c;可以管理集群中的容器化应用程序。在集群中保持所有容器之间的网络连接需要一些高级网络技术。在本文中&#xff0c;我们将简要介绍一些工具和技术&#xff0c;用于检查这种网络设置。 如果您正在调试连接问题&#xff0c;调查…...

如何将网站封装成App:小猪APP分发助你实现

你有没有想过&#xff0c;将你的网站变成一个App会是什么样子&#xff1f;想象一下&#xff0c;用户只需点击一下图标&#xff0c;就能立刻访问你的内容&#xff0c;而不是在浏览器中输入网址。这不仅提升了用户体验&#xff0c;还能增加用户粘性。这一切都可以通过将网站封装成…...

开源治理新范式:Gitee CodePecker SCA如何重塑企业软件供应链安全防线

开源治理新范式&#xff1a;Gitee CodePecker SCA如何重塑企业软件供应链安全防线 当Log4j漏洞席卷全球时&#xff0c;企业第一次意识到开源组件的安全风险可能比想象中更近。据Sonatype《2023年软件供应链状态报告》显示&#xff0c;过去一年中针对开源组件的攻击同比增长了65…...

开源中间件IoTDM:破解物联网数据孤岛,实现异构设备统一管理

1. 项目概述&#xff1a;开源中间件如何成为物联网的“粘合剂”在物联网&#xff08;IoT&#xff09;领域摸爬滚打了十几年&#xff0c;我见过太多“数据孤岛”的困境。智能家居、工业传感器、可穿戴设备……每个设备、每个平台都像一座座信息孤岛&#xff0c;数据格式五花八门…...

工业数据采集新思路:用一台NET30-CS桥接器同时搞定欧姆龙PLC的FINS/TCP和ModbusTCP协议

工业数据采集新思路&#xff1a;NET30-CS桥接器实现欧姆龙PLC双协议并行接入 在工业自动化系统升级过程中&#xff0c;新旧设备协议兼容性问题一直是困扰工程师的技术痛点。当车间里同时存在依赖FINS/TCP协议的老旧监控系统和仅支持ModbusTCP的新型MES平台时&#xff0c;传统解…...

词源探秘|从orient到panorama:解码英语单词背后的文明密码

1. 从日出东方到现代导航&#xff1a;ori词根的文明之旅 当古人第一次观察到太阳从东方升起时&#xff0c;拉丁语用"oriri"&#xff08;升起&#xff09;记录这个现象。这个词根演变为ori&#xff0c;像一条暗线贯穿人类文明&#xff1a; orient&#xff08;东方&a…...

为什么选择update-golang:5大优势对比传统安装方式

为什么选择update-golang&#xff1a;5大优势对比传统安装方式 【免费下载链接】update-golang update-golang is a script to easily fetch and install new Golang releases with minimum system intrusion 项目地址: https://gitcode.com/gh_mirrors/up/update-golang …...

目标检测算法——史上最全遥感数据集汇总附下载链接【速速收藏】

&#x1f680;&#x1f680;&#x1f680; 近期&#xff0c;小海带在空闲之余收集整理了一批遥感检测数据集供大家参考。 整理不易&#xff0c;小伙伴们记得一键三连喔&#xff01;&#xff01;&#xff01;&#x1f388; &#x1f5a5;️ 专注开源数据集分享与深度学习科研思路…...

DevSquad:一体化开发者工具箱,提升本地开发与调试效率

1. 项目概述&#xff1a;DevSquad&#xff0c;一个面向开发者的“瑞士军刀”式工具箱在软件开发这个行当里摸爬滚打十几年&#xff0c;我越来越觉得&#xff0c;一个开发者的效率&#xff0c;很大程度上取决于他手头的“家伙事儿”是否趁手。我们每天都要面对各种琐碎但必要的工…...

【AI模型治理黄金标准】:SITS 2026认证框架首次披露——覆盖LLM/多模态/SFT模型的8维评估矩阵与23项强制基线

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;AI原生模型管理&#xff1a;SITS 2026 MLOps完整解决方案 SITS 2026 是面向AI原生工作负载设计的下一代MLOps平台&#xff0c;深度集成模型生命周期治理、动态推理编排与可信AI审计能力。其核心突破在于…...

学Simulink——基于储能系统参与电网一次调频的下垂控制仿真示例

目录 手把手教你学Simulink——基于储能系统参与电网一次调频的下垂控制仿真示例 一、 引言&#xff1a;当“新能源浪潮”遇见“频率崩塌”——储能如何化身电网的“速效救心丸”&#xff1f; 二、 问题本质&#xff1a;一次调频的“核心挑战”与“协同逻辑” 1. 核心挑战 …...

终极指南:Awoo Installer - Nintendo Switch游戏安装的免费开源解决方案

终极指南&#xff1a;Awoo Installer - Nintendo Switch游戏安装的免费开源解决方案 【免费下载链接】Awoo-Installer A No-Bullshit NSP, NSZ, XCI, and XCZ Installer for Nintendo Switch 项目地址: https://gitcode.com/gh_mirrors/aw/Awoo-Installer 还在为Switch游…...