mysql事务处理

一.抛出问题:

二. 事务:

1.本质:把多个操作,打包成一个操作完成.

2.原子性:多个操作,要么全部执行成功,要么一个都不执行(回滚).

3.回滚(rollback)机制:执行到中间出错了,自动把执行成功的操作还原到最初没有执行的样子.

实现回滚:把事务中每个执行的操作记录下来,如果要回滚,按照逆操作执行.

注意:日志会在硬盘中存在,所以数据库崩溃也不会影响回滚.

4.开启事务:start transaction.

提交事务:commit(自带回滚).

手动触发回滚:rollback.

注意:一个事务必须要以commit或者rollback结尾,否则所有操作都会认为在一个事务中..

5.(重要)事务的基本特性:

a)原子性:多个操作打包成一个整体,要么全部执行成功,要么一个都不执行(回滚).

b)一致性: 事务执行前后,数据能对上(通过约束和回滚保证).

c)持久性:数据存在硬盘上,持久化存储.

d)隔离性:并发执行事务的时候,隔离性会在执行效率和数据可靠之间做出权衡.描述了同时执行事务时,相互之间的影响.

1.特点:隔离性越高,数据越可靠,但是并发性低,性能低,隔离性越低,数据越不可靠,但是并发性高,性能高.

2.并发执行的三个问题:

a).脏读问题:读到了写事务之前的中间数据.

解决方法:对写加锁(写的时候不能读).

read committed.

b)不可重复度问题:一个事务中,多次读操作,读到的数据不一样(另一个事务在修改).

解决方法:给读加锁(读的时候不能写).

repeatable read.

c)幻读问题(不可重复度的更进一步):一个事务中,读数据的时候,突然多出来几条数据,多次读数据,值相同,结果集不同.

解决幻读问题:串行化,彻底放弃并发执行事务,所有事务都是一个挨一个执行.

serializbale.

相关推荐
用户8307196840822 小时前
MySQL 查询优化 30 条封神技巧:用好索引,少耗资源,查询快到飞起
mysql
Nyarlathotep01133 小时前
事务隔离级别
sql·mysql
悟空聊架构3 小时前
基于KaiwuDB在游乐场“刷卡+投币”双模消费系统中的落地实践
数据库·后端·架构
IvorySQL3 小时前
PostgreSQL 技术日报 (3月4日)|硬核干货 + 内核暗流一网打尽
数据库·postgresql·开源
Nyarlathotep01136 小时前
SQL的事务控制
sql·mysql
进击的丸子7 小时前
虹软人脸服务器版SDK(Linux/ARM Pro)多线程调用及性能优化
linux·数据库·后端
用户86178277365187 小时前
MySQL 8.0从库宕机排查实录:中继日志膨胀引发的连锁故障复盘
mysql
NineData1 天前
NineData智能数据管理平台新功能发布|2026年1-2月
数据库·sql·数据分析
IvorySQL1 天前
双星闪耀温哥华:IvorySQL 社区两项议题入选 PGConf.dev 2026
数据库·postgresql·开源
ma_king1 天前
入门 java 和 数据库
java·数据库·后端