MySQL数据库进阶(事务Transaction)

╰半夏微凉° 2023-02-11 11:30 87阅读 0赞

文章目录

        • 1、事务定义
        • 2、事务的四大特征
        • 3、事务操作
        • 4、savepoint练习
        • 5、事务在Python中的使用
        • 6、隔离级别

1、事务定义

1)用于大数据
MySQL 事务用于处理操作量大,复杂度高的数据。比如,在人员管理系统中,删除了一个人员的信息,你既需要删除人员的基本资料,也要删除和该人员相关的信息,如注册号码、信箱,文章等等,这样,这些数据库操作语句就构成一个事务!

2)能保障安全
一个最小的不可再分的工作单元,通常一个事务对应一个完整的业务。如:手机转账,该业务就是一个最小的工作单元,它涉及了你各方面的信息和转账对方的信息,这是一种链接式的。你的账户钱少了,对方账户钱多了,两者必须都成功了,这项操作才算真正结束,如果进行到一半出问题了,你的钱是不会少的,因为这一个事务还没有结束。

3)事务前提

  • 在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。
  • 事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。
  • 事务用来管理 insert,update,delete 语句

综上所述,事务指逻辑上的一组操作,组成这组操作的各个单元,要不全部成功,要不全部不成功。

2、事务的四大特征

1)原子性: 一个事务中的所有操作,要么都发生,要么都不发生,不会结束在中间某个环节。

2)一致性: 在事务开始之前和事务结束以后,数据库的完整性没有被破坏。无论事务是否执行成功,事务结束后的数据库中的数据也应该是符合完整性约束的。

3)隔离性: 多个用户并发访问数据库时,一个用户的事务不能被其它用户的事务所干扰。

4)持久性: 一个事务一旦被提交,就代表一个事务的结束,它对数据的修改就是永久的,即便系统故障也不会丢失。

注意:

在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT
操作。因此要显式地开启一个事务务须使用命令 BEGIN 或 START TRANSACTION,或者执行命令 SET
AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。

3、事务操作

  • 开启事务: Start Transaction
  • 事务结束: End Transaction
  • 提交事务: Commit Transaction
  • 回滚事务: Rollback Transaction
    即撤销指定的sql语句(只能回退insert delete update语句),回滚到上一次commit的位置
  • 设保留点: Savepoint identifier
    事务处理中设置的临时占位符 你可以对它发布回退(与整个事务回退不同)
  • 删保留点: Release Savepoint identifier
  • 改提交模式:
    SET AUTOCOMMIT=0 禁止自动提交
    SET AUTOCOMMIT=1 开启自动提交

4、savepoint练习

1)首先创建带有innodb引擎的数据表

  1. --创建使用事务引擎的数据表(设置engineinnodb
  2. create table emp(id INT PRIMARY KEY auto_increment,name VARCHAR(20)) engine=innodb;
  3. --插入数据
  4. INSERT INTO emp(name) VALUE ("ViewIN"),
  5. ("Zoro"),
  6. ("ZaHuw");

1
2)开启事务,并再插入一个数据

  1. --开启事务
  2. start transaction;
  3. --再次插入数据
  4. insert into emp (name) values ('ZaHuw_tow');
  5. --此时查看,并不会有变化
  6. select * from emp;
  7. --提交之后才会有变化
  8. commit;

然后查看表的内容,会发现并没有新的数据进入,因为我们还没有提交事务。当commit之后,表才会变化。

3)设置保留点

  1. --设置保留点
  2. start transaction;
  3. insert into emp (name) values('OK');
  4. --设置一个名为insert_OK的保留点
  5. savepoint insert_OK;
  6. select * from emp;

2

4)进行删除操作,并再设一个保留点

  1. --进行删除操作
  2. delete from emp where id=5;
  3. --再次设置一个名为delete1的保留点
  4. savepoint delete1;
  5. select * from emp;

5)再删一次,并设保留点

  1. --再删一次,并设保留点
  2. delete from emp where id=3;
  3. savepoint delete2;
  4. select * from emp;

此时已经设置了三个保留点,并且三个操作其实都有效果,当我们使用回滚事务时,就可以返回到对应的保留点处

6)回滚保留点

  1. --回滚保留点
  2. rollback to delete1;
  3. select * from emp;

这样我们就回到了delete1保留点,也就是只删除了id=5的数据
3

5、事务在Python中的使用

  1. import pymysql
  2. # 连接MySQL
  3. conn = pymysql.connect(host='192.168.43.247', port=3306, user='root', passwd='', db='sqlpwd')
  4. # 创建游标
  5. cursor = conn.cursor()
  6. # 创建事务数据表
  7. # CR= "create table account2(id INT PRIMARY KEY auto_increment,name VARCHAR(20)) engine=innodb"
  8. # cursor.execute(CR)
  9. # 插入数据
  10. # into_name= "INSERT INTO account2 (name) VALUE ("ViewIN"),("Zoro"),("ZaHuw")"
  11. # cursor.execute(into_name)
  12. try:
  13. # 插入数据
  14. insertSQL0= "INSERT INTO account2 (name,balance) VALUES ('Zero',4000)"
  15. insertSQL1= "UPDATE account2 set balance=balance-1000 WHERE name='One'"
  16. insertSQL2= "UPDATE account2 set balance=balance+1000 WHERE name='Tow'"
  17. cursor = conn.cursor()
  18. cursor.execute(insertSQL0)
  19. conn.commit()
  20. cursor.execute(insertSQL1)
  21. raise Exception
  22. cursor.execute(insertSQL2)
  23. cursor.close()
  24. conn.commit()
  25. except Exception as e:
  26. conn.rollback()
  27. conn.commit()
  28. cursor.close()
  29. conn.close()

6、隔离级别

1)四种隔离级别

  • Serializable:可避免脏读、不可重复读、虚读情况的发生。(串行化)
  • Repeatable read:可避免脏读、不可重复读情况的发生,不可以避免虚读(可重复读)
  • Read committed:可避免脏读情况发生(读已提交)
  • Read uncommitted:最低级别,以上情况均无法保证。(读未提交)

2)均衡对照

安全性考虑:Serializable > Repeatable read > Read committed > Read uncommitted
数据库效率:Read uncommitted > Read committed > Repeatable read > Serializable

一般情况下,我们会使用Repeatable read、Read committed mysql数据库默认的数据库隔离级别Repeatable read

3)mysql中设置数据库的隔离级别语句:

  1. set [global/session] transaction isolation level xxxx;

注意:如果使用global则修改的是数据库的默认隔离级别,所有新开的窗口的隔离级别继承自这个默认隔离级别如果使用session修改,则修改的是当前客户端的隔离级别,和数据库默认隔离级别无关。当前的客户端是什么隔离级别,就能防止什么隔离级别问题,和其他客户端是什么隔离级别无关。

发表评论

表情:
评论列表 (有 0 条评论,87人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Mysql-事务&锁

    前置知识-事务 事务简介 事务 是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,即这些操作要么同时成功,要

    相关 MySQL事务TRANSACTION

    MySQL 数据库中事务是用户一系列的数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位。 为什么要使用事务 事务具有 4 个特性:原子性(Atomi

    相关 MySQL事务 transaction

    一、为什么要有事务? 用一个很经典的例子: 事务广泛的运用于订单系统、银行系统等多种场景。如果有以下一个场景: A用户和B用户是银行的储户。现在A要给B转账500元...