设为首页 收藏本站
查看: 594|回复: 0

[经验分享] Linux命令:MySQL系列之八--MySQL事务相关内容

[复制链接]

尚未签到

发表于 2018-9-30 10:01:35 | 显示全部楼层 |阅读模式
  MySQL,ODBC    数据库事务
  多事务同时执行:彼此之间互不影响的方式进行并行;事务之间交互,通过数据集。
  START TRANSACTION;  启动事务命令   数据库只有启动了事务才允许回滚撤销等操作。
  且数据的engine引擎必须是innodb,才支持事务
  ROLLBACK 回滚事务,mysql只要没有提交开启了事务都可以进行回滚操作。
  COMMIT:事务提交,事务提交后无法进行回滚操作。
  如果没有明确启动事务:  autocommit能实现自动提交,每一个操作都直接提交;
  所以建议:明确使用事务,否则所有操作都被当成一个事务来处理,并关闭自动提交。
  否则会浪费mysql很多IO操作,每写一条语句都执行提交至持久性存储,很浪费资源
  事务的特性:
  Atomicity:原子性,事务所引起的数据库操作,要不都完成,要么都不执行;
  Consistency: 一致性,
  Isolation:隔离性
  事务调度:事务之间影响最小
  MVCC:多版本并发控制
  Durability:持久性 ,一旦事务成功完成,系统必须保证任何故障都不会引起事务表示出不一致性;
  1、事务提交之前就已经写出数据至持久性存储;
  2、结合事务日志完成;
  事务日志:顺序IO
  数据文件:随机IO
  事务的状态:
  活动的:active
  部分提交的:最后一条语句执行后
  失败的:
  终止的:
  提交的:
  及状态间的转换过程:
DSC0000.jpg

  事务并发执行的优势: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、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-606597-1-1.html 上篇帖子: mysql安装rpm方式 下篇帖子: 浅谈Mysql数据库的备份方案
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表