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

【MySQL】事务

事务是一组操作的集合,我们将一组操作视为一个整体,所以事务里面的操作的时候要么同时成功,要么同时失败,之所以会有事务也是因为我们在实际生活中会用到
最典型的例子就是转账操作:A向B进行转账,A这边扣款成功的同时B那边一定是收款成功的,如果没有事务的话就会出现A扣款成功但B没有收到款的情况

文章目录

  • 1.事务的操作
  • 2.事务的特性
  • 3.并发事务的问题
  • 4.事务隔离级别

1.事务的操作

正常提交事务的流程为: 开始事务->执行操作->提交事务
如果出现异常的话则需要回滚事务

开启事务:begin;
提交事务:commit;
回滚事务:rollback;

begin之后加上要执行的SQL语句即可,然后是commit,提交失败则执行rollback
MySQL的事务默认是自动提交的,当执行一条DML语句时MySQL会自动提交事务,如果你想要修改MySQL提交事务的方式

select @@autocommit;   查看事务提交方式(为啥这两个@颜色还不一样呢(⊙_⊙))
set @@autocommit=0;    0为手动提交,1为自动提交

2.事务的特性

  • 原子性 : 事务是不可分割的最小的操作单元,里面的操作要么全部成功,要么全部失败

  • 一致性 : 事务完成的时候必须使所有的数据保持一致状态

  • 隔离性 : 数据库系统提供的隔离机制,目的是保证事务在不受外部并发操作影响的环境下运行

  • 持久性 : 一个事务一旦被提交,它对数据库中数据所做的改变是永久的

针对隔离性,我们来讲下如果没有隔离性并发事务会造成的问题

3.并发事务的问题

最常见的问题有脏读,不可重复读和幻读

  1. 脏读:指一个事务读取到另一个事务还未提交的数据,如下图
    在这里插入图片描述
    事务1修改了数据,但是还没有提交,此时事务2对数据进行查询,那么事务2就会查询到已经被修改但是还未提交的数据

  2. 不可重复读:一个事务先后读取同一条记录,但两次读取出来的结果是不同的,如图
    在这里插入图片描述
    事务1在两次查询期间,事务2对数据进行了修改并提交事务,导致事务1两次查询的数据结果不一致

  3. 幻读:幻读是在解决不可重复读的基础上出现的新问题,事务在查询某个数据的时候发现数据不存在,于是进行插入数据,但是在插入数据的时候发现数据又存在,就像出现了幻觉一样,如图
    在这里插入图片描述
    由于解决了不可重复度,所以事务1两次select结果均为未找到,但是却无法插入数据

4.事务隔离级别

隔离级别脏读不可重复读幻读
读未提交(read uncommited)×××
读已提交(read commited)××
可重复读(repeatable read)×
串行化(serializable)

上述4个级别,串行化隔离级别最高,可以解决所有的并发事务问题,但同时性能也是最差的,这就需要根据实际情况来选择事务的隔离级别了
在MySQL中默认的隔离级别是可重复读
设置事务的SQL语句如下:

select @@tx_isolation;  查看事务隔离级别(个人使用的5.6版本的SQL语句,下面的是高版本的SQL语句)
select @@transaction_isolation;  set [session/global] transaction isolation level 隔离级别;  设置事务隔离级别,set session是仅当前客户端窗口有效,set global则是所有客户端的窗口都有效

MySQL的基础部分到这基本结束了,主要包括基础的SQL语句,MySQL的函数,数据约束,多表查询和这篇的事务,下一篇开始就开始进阶的内容了,完

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

相关文章:

  • 学习HCIP的day.03
  • Maven项目的配置
  • Spring Boot使用(基础)
  • 6WINDGate-overview
  • Java8新特性-流式操作
  • Nautilus Chain Layer 3 圆桌会议圆满举办,超4.8K用户观看
  • 本地elasticsearch中文分词器 ik分词器安装及使用
  • Java 中的异常处理机制是什么?如何使用它来处理程序中的异常?(七)
  • 基于UDQ的并网单相逆变器控制【同步参考系下单相并网全桥正弦PWM逆变器闭环控制】(Simulink)
  • JAVA开发——常用的注解
  • 【Java笔试强训 24】
  • SpringCloud详解
  • 如何保障网络安全
  • 网络基础:socket套接字
  • 程序员如何学好PHP?做好这五个方面就够了
  • 【开源项目】Build your own X 构建自己的项目
  • 在.NET Core中正确使用HttpClient的方式
  • 【C++】位运算类题目总结
  • Node服务端开发【NPM】
  • Doris(21):Doris的函数—日期函数
  • 和月薪5W的阿里程序员聊过后,才知道自己一直在打杂...
  • 西门子PLC沿脉冲类指令汇总
  • 软件多语言文案脚本自动化方案
  • C++017-C++文件读写应用
  • 计算机网络 实验二
  • Unity 3D 学习笔记(1)
  • P1050 [NOIP2005 普及组] 循环
  • 软考算法-排序篇-上
  • 总结836
  • ginbuilder 工具快速创建