当前位置: 首页 » 网站建设 » 网站建设知识 » 正文

Linux命令:MySQL系列之八--MySQL事务相关内容

发布时间:2025-07-22 以下文章来源于网友投稿,内容仅供参考!

Linux命令:MySQL系列之八--MySQL事务相关内容。

MySQL,ODBC 数据库事务

多事务同时执行:彼此之间互不影响的方式进行并行;事务之间交互,通过数据集。

START TRANSACTION; 启动事务命令 数据库只有启动了事务才允许回滚撤销等操作。

且数据的engine引擎必须是innodb,才支持事务

ROLLBACK回滚事务,mysql只要没有提交开启了事务都可以进行回滚操作。

COMMIT:事务提交,事务提交后无法进行回滚操作。

如果没有明确启动事务: autocommit能实现自动提交,每一个操作都直接提交;

所以建议:明确使用事务,否则所有操作都被当成一个事务来处理,并关闭自动提交。

否则会浪费mysql很多IO操作,每写一条语句都执行提交至持久性存储,很浪费资源

事务的特性:

Atomicity:原子性,事务所引起的数据库操作,要不都完成,要么都不执行;

Consistency: 一致性,

Isolation:隔离性

事务调度:事务之间影响最小

MVCC:多版本并发控制

Durability:持久性 ,一旦事务成功完成,系统必须保证任何故障都不会引起事务表示出不一致性;

1、事务提交之前就已经写出数据至持久性存储;

2、结合事务日志完成;

事务日志:顺序IO

数据文件:随机IO

事务的状态: 活动的:active

部分提交的:最后一条语句执行后

失败的:

终止的:

提交的:

及状态间的转换过程:

事务并发执行的优势:1、提高吞吐量和资源利用率 2、减少等待时间

事务调度:1、可恢复调度 2、无极联调度

实例:

mysql> SELECT @@AUTOCOMMIT; #查询自动提交的状态1为开启,0为关闭;

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

| @@AUTOCOMMIT |

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

| 1 |

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

1 row in set (0.00 sec)

mysql> SET AUTOCOMMIT=0; #设定自动提交关闭

Query OK, 0 rows affected (0.00 sec)

mysql> SELECT @@AUTOCOMMIT; #查询自动提交的状态1为开启,0为关闭;

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

| @@AUTOCOMMIT |

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

| 0 |

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

1 row in set (0.00 sec)

mysql> DELETE FROM student WHERE Name LIKE 'Li%'; #删除Name字段包含Li的行

Query OK, 1 row affected (0.03 sec)

mysql> SELECT * FROM student; #Li哪行已经被删除

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

| SID | Name | Age | CID |

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

| 2 | Cheng Long | 0 | 2 |

| 3 | Yang Guo | 0 | 3 |

| 4 | Guo Jing | 0 | 4 |

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

3 rows in set (0.00 sec)

mysql> ROLLBACK; #回滚事务,自动提交关闭后,默认就开启了事务,可以实现回滚等操作

Query OK, 0 rows affected (0.01 sec)

mysql> SELECT * FROM student; #删除的哪行恢复了

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

| SID | Name | Age | CID |

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

| 1 | Li Lianjie | 0 | 1 |

| 2 | Cheng Long | 0 | 2 |

| 3 | Yang Guo | 0 | 3 |

| 4 | Guo Jing | 0 | 4 |

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

4 rows in set (0.00 sec)

保存点:恢复到所定义的那个保存点SAVEPOINT,保存点名称不能为数字。

保存点:SAVEPOINT savepoint_name; 保存以上操作为该保存点名称

回滚保存点:ROLLBACK TO savepoint_name; 回滚到该保存点之前的状态

Usage:

mysql> START TRANSACTION; #启动事务

Query OK, 0 rows affected (0.00 sec)

mysql> select * FROM student;

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

| SID | Name | Age | CID |

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

| 1 | Li Lianjie | 0 | 1 |

| 2 | Cheng Long | 0 | 2 |

| 3 | Yang Guo | 26 | 3 |

| 4 | Guo Jing | 53 | 4 |

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

4 rows in set (0.00 sec)

mysql>SAVEPOINT a; #该保存点student表数据都存在

Query OK, 0 rows affected (0.00 sec)

mysql> select * FROM student;

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

| SID | Name | Age | CID |

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

| 1 | Li Lianjie | 0 | 1 |

| 2 | Cheng Long | 0 | 2 |

| 3 | Yang Guo | 26 | 3 |

| 4 | Guo Jing | 53 | 4 |

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

4 rows in set (0.00 sec)

mysql> DELETE FROM student WHERE SID=4; #删除student表的SID为4的行

Query OK, 1 row affected (0.00 sec)

mysql> SELECT * FROM student;

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

| SID | Name | Age | CID |

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

| 1 | Li Lianjie | 0 | 1 |

| 2 | Cheng Long | 0 | 2 |

| 3 | Yang Guo | 26 | 3 |

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

3 rows in set (0.00 sec)

mysql> SAVEPOINT b; #该保存点student表数据的SID为4的行不存在了

Query OK, 0 rows affected (0.00 sec)

mysql> DELETE FROM student WHERE SID=3;

Query OK, 1 row affected (0.00 sec)

mysql> SELECT * FROM student;

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

| SID | Name | Age | CID |

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

| 1 | Li Lianjie | 0 | 1 |

| 2 | Cheng Long | 0 | 2 |

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

2 rows in set (0.00 sec)

mysql> SAVEPOINT c; #该保存点student表的SID为3和4的行都不存在

Query OK, 0 rows affected (0.00 sec)

mysql> ROLLBACK TO b; #回滚至保存点b,即student表,SID为4的行不存在的行

Query OK, 0 rows affected (0.00 sec)

mysql> SELECT * FROM student;

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

| SID | Name | Age | CID |

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

| 1 | Li Lianjie | 0 | 1 |

| 2 | Cheng Long | 0 | 2 |

| 3 | Yang Guo | 26 | 3 |

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

3 rows in set (0.00 sec)

mysql> ROLLBACK TO a;#即所有数据都存在的那个点

Query OK, 0 rows affected (0.00 sec)

mysql> SELECT * FROM student;

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

| SID | Name | Age | CID |

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

| 1 | Li Lianjie | 0 | 1 |

| 2 | Cheng Long | 0 | 2 |

| 3 | Yang Guo | 26 | 3 |

| 4 | Guo Jing | 53 | 4 |

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

4 rows in set (0.00 sec)

  • • 宝塔面板中如何在终端重启服务器

    宝塔面板中如何在终端重启服务器宝塔面板是一款功能强大的服务器管理面板,可以帮助管理员简化服务器操作。当需要重启服务器时,

  • • 宝塔面板如何在线编辑

    宝塔面板如何在线编辑宝塔面板是一款功能强大的服务器管理面板,它提供了很多方便实用的功能。其中之一就是在线编辑文件的功能,

  • • 宝塔面板需要什么

    宝塔面板需要什么宝塔面板是一款非常流行的服务器管理软件,广泛应用于网站搭建和服务器管理。使用宝塔面板可以简化服务器操作,

  • • 如何备案阿里云服务器地址

    如何备案阿里云服务器地址备案是指互联网信息服务提供者按照国家相关规定,将其域名与服务器地址等信息进行报备并获得许可的过程

  • • 高级宝塔面板怎么拆卸视频

    高级宝塔面板怎么拆卸视频今天我们来分享一下高级宝塔面板的拆卸方法。以下是详细步骤:首先,确保你已经备份了所有数据,并且登

  • 植物大战僵尸bt版宅宅萝卜最新版下载
    ehviewer官网下载网站入口
    51漫画APP最新官方版下载
    免费追剧app软件下载
    茶杯狐cupfox官方app下载
    海马云电脑app下载
    joiplay官方下载
    局域网IP扫描软件下载
    暗部口袋2025最新版下载
    雷霆加器速官网下载
    失信人信息查询:http://zxgk.court.gov.cn
    2025白露是哪一天?白露是几月几日几时几分几秒
    白露是几月几日2025?2025年白露阳历时间
    无尽冬日最强阵容是什么?
    无尽冬日英雄培养顺序
    二手房需要维修基金吗?维修基金使用的条件
    买房摇号要摇到号才能选房吗?摇号选房的大概流程
    购买法拍房需要交哪些税费?买法拍房需注意什么问题
    2025年阅兵具体日期是哪天?2025年阅兵的具体时间表
    2025年9月3日北京交通管制情况如何?2025年阅兵期间如何绕行北京?