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

MySQL事务

文章目录

  • MySQL事务
    • 事务的四个特性 ACID
    • 事务提交的类型
      • 事务的使用

MySQL事务

事务是什么?

事务就是一组逻辑操作单元,是数据从一种状态变成另外一种状态。整个单元有一个或多个SQL语句构成,在这个操作单元中,每一个SQL语句相互依赖、不可分割,是一个整体。

事务处理(事务操作)?

保证所有的事务都作为一个工作单元来执行,即使出现了故障,都不要改变这种执行方式。但在一个事务中执行多个操作时,要么整个事务被commit,那样这些修改就会保存下来;要么数据库管理系统将放弃所有的修改,整个事务rollback到最初的状态

这个操作其实是为了确保数据的一致性,这样不论这个被commit还是rollback,都可以做到让数据库从一个一致性状态变换到另一个一致性状态。

事务的四个特性 ACID

事务是由一组SQL语句组成的逻辑处理单元,它的ACID特性如下:

  • 原子性(Atomicity):原子性是指事务是一个不可分割的单位,事务中的操作要么都发生,要么都不发生。
  • 一致性(Consistency):事务必须使数据库从一个一致性状态变换到另外一个一致性状态。
  • 隔离性(lsolation):事务的隔离性是指多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务操作的数据所干扰,多个并发事务之间要相互隔离。
  • 持久性(Durability):持久性是指一个事务一旦被commit,他对数据库中数据的改变就是永久的,接下的其他操作或故障不应对其有任何影响。

在这里插入图片描述

事务提交的类型

  1. *隐式提交:*即无需显示执行commit语句,session中的操作被自动提交到数据库的过程。

  2. *自动提交:*若把AUTOCOMMIT设置为ON,则在插入、修改、删除语句执行后,
    系统将自动进行提交,这就是自动提交。

    set autocommit on;

  3. 显式提交:用COMMIT命令直接完成的提交为显式提交。

    commit;

隐式提交的方式?

  • 正常执行完DDL语句。包括create,alter,drop,truncate,rename。
  • 正常执行完DCL语句。包括grant,revoke。
  • 正常退出数据库管理软件,没有明确发出commit或者rollback。

其实在执行DDL语句时,前面的DML操作也会被提交到数据库中,因为是在一个session里,那执行ddl语句的时候前面的dml语句也会被提交到库中。即使DDL语句执行失败,前面的DML操作也会被提交到数据库中,

DDL都执行失败了,怎么还会提交呢?这就需要探究一下隐式提交的本质了,为了避免隐式提交或者回滚,尽量保证一条或者几条DML操作完成后有显示的提交或者回滚,防止后续执行的DCL或者DDL自动提交前期的DML操作。

隐式提交的本质:

一条DDL语句执行了两次commit

commit; —将当前session中未提交的事务隐式提交,以保证DDL语句失败时的回滚位置

DDL statement;

commit; —将DDL操作提交

事务的使用

  • begin/start transaction开启事务
  • 编写事务中的sql语句
  • commit rollback 结束事务:提交或回滚
http://www.lryc.cn/news/5922.html

相关文章:

  • CData Drivers for Acumatica
  • 智慧税务+数据可视化:企业财务管理告别难题
  • Ansible中常用的模块
  • 问:你是如何进行react状态管理方案选择的?
  • 【华为OD机试真题 java、python、jsNode】任务总执行时长【2022 Q4 100分】
  • react基础
  • 【Spark分布式内存计算框架——Spark SQL】2. SparkSQL 概述(上)
  • Kubeadm搭建K8S
  • 【技术分享】搭建java项目引入外部依赖教程
  • 算法 ——世界 二
  • 数据治理CDGP选择题 4
  • 动态规划之01背包问题和完全背包问题
  • MATLAB算法实战应用案例精讲-【图像处理】数字图像灰度化(附Java、python、matlab和opencv代码实现)
  • Linux(强大的yum命令)
  • 28.结语
  • ICRS、GCRS、CIRS、TIRS和ITRS坐标系统简介
  • 你是真的“C”——详解结构体知识点
  • 2023新华为OD机试题 - 单词接龙(JavaScript) | 刷完必过
  • 第一章 一般错误信息 - 错误代码 0 到 99
  • MyBatis 之一(概念、创建项目、操作模式、交互流程)
  • 学习笔记:文件
  • 高考结束了以后应该做的事情(个人经历的总结)
  • 蓝桥杯:k倍区间
  • 【思维模型】概率思维的价值:找到你的人生算法!打开你的人生格局!实现认知跃迁!
  • API文档自动生成工具
  • 7、MyBatis框架——MyBatis对一对一关系的处理、分步查询、MyBatis对一对多关系的处理
  • 电商数据监测——中国白酒行业数据浅析
  • excel数据技巧:透视表快速统计年终业绩排名
  • TensorRT的Python接口解析
  • 【信管11.5】合同、采购、招投标相关法规