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.

相关推荐
风子杨yxf77127 分钟前
linux下oracle开机自启动以及关机自关闭数据库,并发送邮件通知
linux·运维·数据库·oracle·自启动·发邮件·自关闭
战族狼魂32 分钟前
基于LibreOffice +python 实现一个小型销售管理系统的数据库原型教学实验
数据库·python
m0_6403093037 分钟前
PHP函数怎样适配高可靠性存储硬件_PHP在ZFS RAIDZ环境配置【技巧】
jvm·数据库·python
踏浪无痕38 分钟前
用 AI 解决数据库性能问题的方法论
数据库
hnmpf1 小时前
linux系统离线环境安装mysql问题
linux·运维·mysql
2402_854808371 小时前
Django REST Framework 中实现用户资料更新的完整实践指南
jvm·数据库·python
m0_748839491 小时前
golang如何理解weak pointer弱引用_golang weak pointer弱引用总结
jvm·数据库·python
m0_738120721 小时前
渗透测试基础ctfshow——Web应用安全与防护(五)
前端·网络·数据库·windows·python·sql·安全
踏着七彩祥云的小丑1 小时前
云服务器——MySQL设置
服务器·mysql
2401_865439632 小时前
mysql如何处理升级后的身份认证兼容性_mysql_native_password配置
jvm·数据库·python