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

如何在 MySQL 中创建和使用事务?

目录

1. 环境准备

2. 创建事务

3. 事务执行

4. 事务撤消

5. 总结 


事务是数据库区别于文件系统的重要特征之一,当我们有了事务就会让数据库始终保持一致,同时我们还能通过事务机制恢复到某个时间点,这样可以保证已提交到数据库的修改不会因为系统崩溃而丢失。

以下是针对MYSQL中如何创建和使用事务的相关的介绍,SQL语句的执行可以使用MySQL Workbench或SQLynx来执行,以下是使用SQLynx执行的截图。(如何安装MySQL和SQLynx的步骤不在此文中介绍,如有需要,可搜索相关的产品网上进行安装)

1. 环境准备

a. 创建users的表,此表包含两个字段 nameemail,建表语句如下:

CREATE TABLE `users` (`name` varchar(100) DEFAULT NULL,`email` varchar(100) DEFAULT NULL
) 

b. 执行以上语句,创建users表,执行成功后如下图所示:

2. 创建事务

a. 打开保持连接的选项,只有保持连接,当前的事务才能按代码行执行。

b. 首先需要使用“START TRANSACTION”语句启动事务。以下是示例:

START TRANSACTION;INSERT INTO users (name, email) VALUES ('John Doe', 'johndoe@example.com');

在此示例中,使用 START TRANSACTION 语句启动了一个新事务。

c. 检查事务执行的结果

1)在当前的连接1中,可以查看到数据执行的结果,如下图:

2)打开一个新的连接2,再次执行查询的语句,可以看到,在表中没有数据:

3. 事务执行

接下来的语句(insert )在该事务内执行。

下一步是提交更改以确保它们是永久的。我们通过在查询中包含 COMMIT 语句来实现这一点。

START TRANSACTION;INSERT INTO users (name, email) VALUES ('John Doe', 'johndoe@example.com');
COMMIT;

在上述新的连接2中,再次查询数据结果,发现数据已经永久保存到表中并能查询出来:

4. 事务撤消

如果事务期间偶然出现错误,并且您想要撤消更改,则可以使用 ROLLBACK 语句。然后事务将被回滚,并且不会执行插入和更新语句。这意味着数据库中不会发生任何更改。

START TRANSACTION;INSERT INTO users (name, email) VALUES ('John Doe', 'johndoe@example.com');
ROLLBACK;

5. 总结 

MySQL一个事务中执行多个操作时,要么所有的事务都被提交(commit),要么这些修改永久地保存下来,要么书库管理系统将放弃所有的修改,整个事务回滚(rollback)到最终状态。

事务对于MySQL在业务生产系统中的作用非常重要,以上示例主要显示的数据的隔离性。当多条数据同时执行的时候,事务会保证业务执行同时成功或同时失败,这样使用有关联性的业务可以保持业务的一致性。

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

相关文章:

  • Python数据分析-对驾驶安全数据进行了预测
  • 全志 Android 11:实现响应全局按键
  • DVWA 靶场 Open HTTP Redirect 通关解析
  • Blender:渲染输出
  • NTFS和exFAT哪个性能好 U盘格式化NTFS好还是exFAT好 mac不能读取移动硬盘怎么解决
  • kafka的基本模型
  • npm语义化版本和版本运算符
  • 孩子到了叛逆期,家长应该怎么教育孩子?
  • 芋道源码 yudao-cloud 、Boot 文档,开发指南 看全部,破解[芋道快速开发平台 Boot + Cloud]
  • 工具函数-算法
  • C# yolov8 OpenVINO 同步、异步接口视频推理
  • 【STM32入门学习】定时器与PWM的LED控制
  • PyTorch实战:模型训练中的特征图可视化技巧
  • 有人@你!神工坊知识问答第二期中奖名单新鲜出炉
  • 数据结构篇:旋转操作在AVL树中的实现过程
  • 为什么Java默认使用UTF-16,Golang默认使用UTF-8呢?
  • JavaScript常见面试题(三)
  • 【Effective Modern C++】第1章 型别推导
  • 服装连锁实体店bC一体化运营方案
  • IDEA中SpringMVC的运行环境问题
  • Python初体验
  • 从零开始如何学习人工智能?
  • 【仿真建模-anylogic】动态生成ConveyorCustomStation
  • 如何使用idea连接Oracle数据库?
  • 谈谈kafaka的并行处理,顺带讲讲rabbitmq
  • P3056 [USACO12NOV] Clumsy Cows S
  • 智赢选品,OZON数据分析选品利器丨萌啦OZON数据
  • Canal自定义客户端
  • 20240621将需要自启动的部分放到RK3588平台的Buildroot系统的rcS文件中
  • 掌握数据魔方:Xinstall引领ASA全链路数据归因新纪元