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.

相关推荐
xiucai_cs10 分钟前
MySQL深分页慢问题及性能优化
数据库·mysql·性能优化·深分页
当牛作馬11 分钟前
ES常用查询命令
数据库·mysql·elasticsearch
chenglin0162 小时前
ES_索引的操作
大数据·数据库·elasticsearch
hzp6663 小时前
阿里云的centos8 服务器安装MySQL 8.0
mysql·阿里云·centos8
共享家95273 小时前
MYSQL库及表的操作
数据库
想回家的一天5 小时前
Go1.25的源码分析-src/runtime/runtime1.go(GMP)
数据库·redis·缓存
阿里云大数据AI技术6 小时前
鹰角网络基于阿里云EMR Serverless StarRocks的实时分析工程实践
数据库·数据分析
久笙&6 小时前
对象存储解决方案:MinIO 的架构与代码实战
数据库·python·架构
码luffyliu7 小时前
MySQL:MVCC机制及其在Java秋招中的高频考点
java·数据库·mysql·事务·并发·mvcc
水涵幽树7 小时前
MySQL 时间筛选避坑指南:为什么格式化字符串比较会出错?
数据库·后端·sql·mysql·database