Linux命令:MySQL系列之八--MySQL事务相关内容
admin
2023-05-19 09:02:24
0


MySQL,ODBC    数据库事务

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


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

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

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

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

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

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

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

事务的特性:

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

   Consistency: 一致性,

   Isolation:隔离性

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

       MVCC:多版本并发控制

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

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

                   2、结合事务日志完成;

                              事务日志:顺序IO

                              数据文件:随机IO

 事务的状态:
             活动的:active

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

               失败的:

               终止的:

               提交的:

及状态间的转换过程:

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

  事务并发执行的优势: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)




相关内容

热门资讯

湖北恩施旅游客车侧翻致1死3伤 记者从湖北省相关部门获悉,5月17日14时56分许,一辆旅游客车在湖北省恩施市境内,发生侧翻事故。事...
因乘客咬伤空乘人员,澳洲航空一... 【环球网报道】据英国《卫报》、法新社等媒体报道,因一名男性乘客涉嫌咬伤空乘人员,澳大利亚澳洲航空公司...
记者手记:从“聪明的路”到“智... 新华社北京5月16日电 记者手记:从“聪明的路”到“智慧的海”,触摸未来交通科技脉搏 新华社记者王聿...
没有明星大导的潮汕方言电影凭什... 五一档最大黑马《给阿嬷的情书》正在持续热映。这部全素人阵容、成本仅1400万的地方电影,像木棉花一样...
80后地产女王自杀,倒在楼市黎... 楼市回暖之际,房地产界却传出了一个噩耗:5月12日,香港乐风集团创始人周佩贤在住所内自杀身亡,年仅4...
苏州能模维申请服务器液冷散热器... 国家知识产权局信息显示,苏州能模维系统有限公司申请一项名为“一种服务器液冷散热器”的专利,公开号CN...
华为申请通信方法、设备和可读存... 国家知识产权局信息显示,华为技术有限公司申请一项名为“通信方法、设备和可读存储介质”的专利,公开号C...
批赖清德当局误判“台美关系”,... 海峡导报综合报道 美国总统特朗普结束访华行程后,外媒陆续报道其涉台相关说法。中国国民党17日批评民进...
家用冰箱温度调多少度合适 冰箱温度调节根据季节不同、需求不同来设定。通常来说夏季室外温度较高,控温可以调节在3-4档位,同时温...
智能冰箱温度调到多少合适 一般的食物适合的温度,新鲜食品区域推荐的温度是2.7-4.4℃,冷冻室的温度是-15℃。如果有单独的...