MySQL事务

文章详细介绍了MySQL事务的概念,强调了事务的ACID特性,包括原子性、一致性、隔离性和持久性。同时,讨论了事务的提交类型,如隐式提交(在DDL或DCL语句执行时)和显式提交,并提醒用户注意隐式提交可能带来的数据提交风险,建议在事务操作中使用显式提交以确保数据控制的准确性。
摘要由CSDN通过智能技术生成

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 结束事务:提交或回滚
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿瑾~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值