我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql 事务解析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql 事务解析

事务(transaction)

事务是业务逻辑的一个基本的单元组成。

每一个事务由一条条sql语句组成。

和事务相关的语句(insert,delete,update)这些DML语句

事务的存在保证了数据的安全性。

事务机制:

每一次执行DML语句都会记录操作,但不会修改数据,等到所有DML执行,

最后提交事务(删除记录,修改硬盘数据)或者回滚事务(删除记录,不修改数据)。

事务由四大特性:ACID

  • A:原子性,事务是最小的工作单元
  • C:一致性,事务中的DML语句要么都执行成功,要么都失败
  • I:隔离性,事务与事务之间隔离。
  • D:持久性,最后数据持久化到硬盘,才会结束

事务的隔离级别:

1.读未提交(read uncommitted),表示一个事务可以读取到另一个事务没有提交的数据

这种级别存在脏读现象

2.读以提交(read committed),可以读取到已经提交的数据

这种级别解决了脏读现象,但是不可以重复读

3.可重复读(repeatable read),事务读取的数据,与其他事务提交数据无关,可以重复读取,事务开始的数据。

解决了不可重复读现象,但是存在幻读,读取到的数据不真实。

4.序列化读/串行化读。解决了所有问题,和多线程里面的线程安全相似。但是存在效率低下。因为事务需要排队。

mysql数据库默认的隔离级别是第三级别。可重复读。

mysql事务默认自动提交。执行一条DML直接修改硬盘上的数据。

想要手动提交事务。在执行DML之前。先start transaction;然后执行DML,最后提交或者回滚。

演示手动回滚事务:


drop table if exists t_user1;

create table t_user1(

id int(3) primary key auto_increment,

username varchar(10)

);

mysql> create table t_user1(

-> id int(3) primary key auto_increment,

-> username varchar(10)

-> );

Query OK, 0 rows affected (0.02 sec)

mysql> insert into t_user1(username) values('h1');

Query OK, 1 row affected (0.01 sec)

mysql> select * from t_user1;

+----+----------+

| id | username |

+----+----------+

| 1 | h1 |

+----+----------+

1 row in set (0.00 sec)

mysql> rollback;//回滚事务

Query OK, 0 rows affected (0.00 sec)

mysql> select * from t_user1;//回滚之后还是和之前一样,因为myql自动提交了

+----+----------+

| id | username |

+----+----------+

| 1 | h1 |

+----+----------+

1 row in set (0.00 sec)

mysql> start transaction;//手动开启事务,关闭事务自动提交

Query OK, 0 rows affected (0.00 sec)

mysql> insert into t_user1(username) values('h2');

Query OK, 1 row affected (0.01 sec)

mysql> insert into t_user1(username) values('h3');

Query OK, 1 row affected (0.00 sec)

mysql> insert into t_user1(username) values('h4');

Query OK, 1 row affected (0.00 sec)

mysql> select * from t_user1;

+----+----------+

| id | username |

+----+----------+

| 1 | h1 |

| 2 | h2 |

| 3 | h3 |

| 4 | h4 |

+----+----------+

4 rows in set (0.00 sec)

mysql> rollback;//回滚

Query OK, 0 rows affected (0.01 sec)

mysql> select * from t_user1;

+----+----------+

| id | username | 最后硬盘上的数据还是和之前一样。

+----+----------+ 回滚删除记录,不修改硬盘上的数据。

| 1 | h1 |

+----+----------+

1 row in set (0.00 sec)

到此这篇关于mysql 事务解析的文章就介绍到这了,更多相关mysql 事务内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql 事务解析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL事务ACID原理深度解析

什么是MySQL事务?事务是指对数据库的一组操作的集合,集合中的SQL语句要么全部执行成功,要么就全部失败,如果集合中任一操作出错,则此集合所有对数据库的操作全部回滚。以常见的购物操作举例,用户下单后要执行订单创建、减库存等一系列操作,这些操作就是一个事务,以
MySQL事务ACID原理深度解析
2018-05-21

浅析MySQL 锁和事务

MySQL本身也是在文件系统的基础上发展而来,因为锁的存在使之有所不同。MySQL作为一种数据库软件,难免会存在对其共享资源的并发访问,为了协调和管理不同资源的并发访问,也就产生了锁机制,因为锁机制的存在为数据库提供了数据的完整性和一致性。
2022-05-13

MySQL事务实例分析

这篇“MySQL事务实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL事务实例分析”文章吧。MySQL 事务主
2023-06-28

Mysql事务特性和级别原理解析

一、什么是事务?数据库事务(简称:事务)是数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。 二、事务的四大属性分别是原子性、一致性、隔离性、持久性。 1、原子性(Atomicity)原子性是指事务包含的所有操作要么全
2022-05-19

mysql事务详解

事务的特性(Atomicity) 原子性 -- 回滚日志一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一
mysql事务详解
2016-12-01

Mysql事务隔离级别原理实例解析

引言 大家在面试中一定碰到过 说说事务的隔离级别吧? 老实说,事务隔离级别这个问题,无论是校招还是社招,面试官都爱问!然而目前网上很多文章,说句实在话啊,我看了后我都怀疑作者弄懂没!因为他们对可重复读(Repeatable Read)和串行
2022-05-29

mysql与事务、恢复相关的参数解析

1、崩溃恢复相关参数解析:innodb_fast_shutdown: innodb_fast_shutdown = 0:这个表示在MySQL关闭的时候,执行slow shutdown,不但包括日志的刷盘,数据页的刷盘,还包括数据的清理(purge),ibuf的
mysql与事务、恢复相关的参数解析
2015-12-10

MySQL的事务详解

✨博客主页: 荣 ✨系列专栏: MySQL ✨一句短话: 难在坚持,贵在坚持,成在坚持! 文章目录 一. 事务的业务场景二. 事务的使用三. 事务的特性(ACID)1. 原子性(Atomicity)2. 一致性(Consistenc
2023-08-17

Spring事务原理解析

Spring事务有可能会提交,回滚、挂起、恢复,所以Spring事务提供了一种机制,可以让程序员来监听当前Spring事务所处于的状态,这篇文章主要介绍了Spring底层事务原理,需要的朋友可以参考下
2022-12-20

编程热搜

目录