mysql 事物

MySQL中的事务(Transaction)是一个确保数据完整性和一致性的重要概念。它将一组SQL操作捆绑在一起,当作一个单一的工作单元来执行。事务具备以下四个关键特性,即ACID特性:

  1. 原子性(Atomicity):事务是原子操作,意味着事务中的所有操作要么全部成功执行,要么全部不执行。如果事务中的任何一部分失败,整个事务都会被回滚,从而保持数据库的一致性。

  2. 一致性(Consistency):事务执行前后,数据库的状态都保持一致。即使事务中包含多个操作,事务结束时,所有数据仍然满足所有的预定义规则,如外键约束、唯一性约束等。

  3. 隔离性(Isolation):在并发环境中,事务之间应该是隔离的,即一个事务不应该看到另一个事务未提交的数据。MySQL 提供了不同的事务隔离级别来控制事务之间的可见性,包括读未提交(Read Uncommitted)、读已提交(Read Committed)、可重复读(Repeatable Read)和串行化(Serializable)。

  4. 持久性(Durability):一旦事务被提交,它对数据库的改变就是永久性的,即使系统发生故障也不会丢失。事务的更改会被持久化到硬盘上的数据库文件中。

在MySQL中,可以通过以下方式来管理事务:

  • 开始事务 :可以使用START TRANSACTIONBEGIN语句显式开始一个新的事务。
  • 提交事务 :使用COMMIT语句来提交事务,将事务中所有更改永久保存到数据库中。
  • 回滚事务 :使用ROLLBACK语句可以撤销事务中所有未提交的更改,恢复到事务开始前的状态。
  • 设置事务隔离级别 :使用SET SESSION TRANSACTION ISOLATION LEVEL语句可以设置当前会话的事务隔离级别。
相关推荐
檀越剑指大厂3 分钟前
金仓数据库:多模融合,一库承载未来,驱动数字化转型新范式
数据库
啊吧怪不啊吧1 小时前
极致性能的服务器Redis之String类型及相关指令介绍
网络·数据库·redis·分布式·mybatis
zihan03211 小时前
Redis Windows版本默认配置文件,Redis配置不生效解决方案
数据库·redis·缓存
强子感冒了2 小时前
MYSQL学习笔记:DML & DQL 核心语法
笔记·学习·mysql
Hgfdsaqwr2 小时前
实战:用Python开发一个简单的区块链
jvm·数据库·python
砚边数影2 小时前
InfluxDB迁移替换实战:金仓时序数据库如何提高写入性能
数据库·性能优化·时序数据库·kingbase·kingbasees·金仓数据库
eWidget9 小时前
InfluxDB迁移至金仓数据库的同城容灾实践:性能显著提升、运维效率优化,某能源企业实现RPO_5秒的高可靠时序数据管理
运维·数据库·能源·时序数据库·kingbase·kingbasees·金仓数据库
小句9 小时前
MySQL慢查询日志详细使用指南
数据库·mysql·adb
老邓计算机毕设10 小时前
SSM医疗资源普查6qxol(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·javaweb开发·医疗资源管理
dyyx11110 小时前
如何从Python初学者进阶为专家?
jvm·数据库·python