Mysql数据库事务的特性及运用
admin
2023-05-23 13:22:37
0
  • 本文主要给大家简单讲讲Mysql数据库事务的特性及运用,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望Mysql数据库事务的特性及运用这篇文章可以给大家带来一些实际帮助。

二、MySQL,ODBC    数据库事务

2.1.多事务同时执行:

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


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

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

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

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


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

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

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


2.2.事务的特性:

  2.2.1.Atomicity:  原子性

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

  2.2.2.Consistency: 一致性

  2.2.3.Isolation:  隔离性

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

       MVCC:   多版本并发控制

  2.2.4.Durability: 持久性 

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

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

                   2、结合事务日志完成;

                              事务日志:顺序IO

                              数据文件:随机IO

 2.3.事务的状态:

             活动的:    active

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

               失败的:

               终止的:

               提交的:

状态间的转换过程        

Mysql数据库事务的特性及运用

   2.4.事务并发执行的优势:

              1、提高吞吐量和资源利用率     2、减少等待时间


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


三、实例:

3.1. 设置自动提交开关

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)


3.2. 回滚事务

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

Query OK, 0 rows affected (0.00 sec)

mysql> commit     #将之前的事务全部提交

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)

      

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

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

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


3.2. 1.保存点实验一

mysql>  START TRANSACTION;             #启动事务

Query OK, 0 rows affected (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)


3.2.2.保存点实验二

     3.2.2.1.设置a2、a4、a6、a8四个保存点

mysql> select * from tutors;

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

| TID | Tname   | Gender | Age  |

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

|   1 | HongQigong   | M      |   93 |

|   2 | HuangYaoshi  | M      |   63 |

|   3 | Miejueshitai | F      |   72 |

|   4 | OuYangfeng   | M      |   76 |

|   5 | YiDeng       | M      |   90 |

|   6 | YuCanghai    | M      |   56 |

|   7 | Jinlunfawang | M      |   67 |

|   8 | HuYidao      | M      |   42 |

|   9 | NingZhongze  | F      |   49 |

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

9 rows in set (0.00 sec)


mysql> delete from tutors where TID = 2 ;

Query OK, 1 row affected (0.00 sec)


mysql> savepoint a2 ;

Query OK, 0 rows affected (0.00 sec)


mysql> delete from tutors where TID = 4 ;

Query OK, 1 row affected (0.00 sec)


mysql> savepoint a4;

Query OK, 0 rows affected (0.00 sec)


mysql> delete from tutors where TID = 6 ;

Query OK, 1 row affected (0.00 sec)


mysql> savepoint a6;

Query OK, 0 rows affected (0.00 sec)


mysql> delete from tutors where TID = 8 ;

Query OK, 1 row affected (0.00 sec)


mysql> savepoint a8;

Query OK, 0 rows affected (0.00 sec)


mysql> select * from tutors;

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

| TID | Tname   | Gender | Age  |

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

|   1 | HongQigong   | M      |   93 |

|   3 | Miejueshitai | F      |   72 |

|   5 | YiDeng       | M      |   90 |

|   7 | Jinlunfawang | M      |   67 |

|   9 | NingZhongze  | F      |   49 |

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

5 rows in set (0.00 sec)


     3.2.2.回滚到a4保存点OK

mysql> rollback to a4;

Query OK, 0 rows affected (0.00 sec)


mysql> select * from tutors;

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

| TID | Tname    | Gender | Age  |

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

|   1 | HongQigong | M      |   93 |

|   3 | Miejueshitai | F      |   72 |

|   5 | YiDeng     | M      |   90 |

|   6 | YuCanghai  | M      |   56 |

|   7 | Jinlunfawang | M      |   67 |

|   8 | HuYidao    | M      |   42 |

|   9 | NingZhongze  | F      |   49 |

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

7 rows in set (0.00 sec)


     3.2.3.再回滚到a6保存点失败,该保存点已不存在

mysql> rollback to a6;

ERROR 1305 (42000): SAVEPOINT a6 does not exist


     3.2.4.但再回滚到a2保存点OK

mysql> rollback to a2;

Query OK, 0 rows affected (0.00 sec)


mysql> select * from tutors;

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

| TID | Tname        | Gender | Age  |

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

|   1 | HongQigong   | M      |   93 |

|   3 | Miejueshitai | F      |   72 |

|   4 | OuYangfeng   | M      |   76 |

|   5 | YiDeng       | M      |   90 |

|   6 | YuCanghai    | M      |   56 |

|   7 | Jinlunfawang | M      |   67 |

|   8 | HuYidao      | M      |   42 |

|   9 | NingZhongze  | F      |   49 |

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

8 rows in set (0.00 sec)


     3.2.5.但再回滚到最原始保存点OK

mysql> rollback;

Query OK, 0 rows affected (0.00 sec)


mysql> select * from tutors;

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

| TID | Tname        | Gender | Age  |

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

|   1 | HongQigong   | M      |   93 |

|   2 | HuangYaoshi  | M      |   63 |

|   3 | Miejueshitai | F      |   72 |

|   4 | OuYangfeng   | M      |   76 |

|   5 | YiDeng       | M      |   90 |

|   6 | YuCanghai    | M      |   56 |

|   7 | Jinlunfawang | M      |   67 |

|   8 | HuYidao      | M      |   42 |

|   9 | NingZhongze  | F      |   49 |

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

9 rows in set (0.00 sec)


     3.2.6.回滚到最原始保存点后,但再回滚a8、a2R失败

mysql> rollback to a8;

ERROR 1305 (42000): SAVEPOINT a8 does not exist

mysql> rollback to a2;

ERROR 1305 (42000): SAVEPOINT a2 does not exist

Mysql数据库事务的特性及运用就先给大家讲到这里,对于其它相关问题大家想要了解的可以持续关注我们的行业资讯。我们的板块内容每天都会捕捉一些行业新闻及专业知识分享给大家的。

相关内容

热门资讯

2026年成都市科技活动周即将... 记者从成都市科技局获悉,5月23日晚,2026年四川省科技活动周暨蓉城科学之夜启动仪式将在成都天府艺...
河南制造,“小满时刻” 【大河财立方 记者 王磊彬 文图】立夏之后,小满将至。中原沃野之上,千万亩小麦正进入籽粒灌浆、日渐充...
败诉后,马斯克表示“不服” 就美国企业家埃隆·马斯克针对开放人工智能研究中心(OpenAI)的诉讼,加利福尼亚州奥克兰市一家联邦...
美媒称美对古巴“动武”可能性在... 新华社华盛顿5月18日电 美国《政治报》网站18日刊文称,由于美国对古巴采取的施压手段并未奏效,美国...
洗衣机底部涡轮掉了怎么办 当洗衣机底部的涡轮掉了,家庭洗衣机可能在开机时会发出异常的声响,出现晃动、不稳定等现象,甚至无法正常...
@河南人 明天阳光“限时返场”... 明日雨水短暂停歇5月18日6时至19日6时,东部、南部出现小到中阵雨、雷阵雨,其中商丘东部、南阳东南...
内嵌式洗脸盆掉了怎么办 如果内嵌式洗脸盆掉了,可以考虑以下解决方法:1. 检查原因:确定洗脸盆掉落的原因,例如安装不牢固、台...
墙面瓷片脱落怎么处理 1、大面积的空鼓。碰上这种情况那就只能是全部拆下再重新铺贴。2、如果是墙砖少量局部空鼓。如果所在的位...
做过仿瓷的墙面怎样翻新 老墙面在翻新前一定要做墙面基底处理,粉化严重的要全部铲除,铲除后用白水泥上一遍。如果原来的墙面过于光...
美瓷胶和美缝剂的区别 德高 大家在购买美瓷胶和美缝剂的时候,都会优先选择那些比较有名的品牌,例如德高,德高应该算得上是一线品牌了...