美文网首页MYSQL
9.MySQL中的事务

9.MySQL中的事务

作者: Stone_説 | 来源:发表于2020-07-21 22:04 被阅读0次

    目录:
    1.事务的特性
    2.事务的生命周期
    3.事务的操作
    4.事务的隔离级别

    1. 事务的特特性

    事务Transactions:一组原子性的SQL语句,或一个独立工作单元

    事务日志:记录事务信息,实现undo,redo等故障恢复功能
    ACID特性:
    A: atomicity原子性;整个事务中的所有操作要么全部成功执行,要么全部失败后回滚
    C: consistency一致性;数据库总是从一个一致性状态转换为另一个一致性状态
    I: Isolation隔离性;一个事务所做出的操作在提交之前,是不能为其它事务所见;隔离有多种隔离级别,实现并发
    D: durability持久性;一旦事务提交,其所做的修改会永久保存于数据库中
    

    2. 事务的生命周期

    Transaction生命周期.jpg

    3. 事务的操作

    启动事务

    BEGIN
    BEGIN WORK
    START TRANSACTION
    

    结束事务:

    COMMIT:提交
    ROLLBACK: 回滚
    注意:只有事务型存储引擎中的DML语句方能支持此类操作
    自动提交: set autocommit={1|0} 默认为1,为0时设为非自动提交
    建议:显式请求和提交事务,而不要使用“自动提交”功能
    事务支持保存点: savepoint
    SAVEPOINT identifier
    ROLLBACK [WORK] TO [SAVEPOINT] identifier
    RELEASE SAVEPOINT identifier
    

    4.事务的隔离级别

    从上至下更加严格

    READ UNCOMMITTED 可读取到未提交数据,产生脏读
    READ COMMITTED 可读取到提交数据,但未提交数据不可读,产生不可重复读,即可读取到多个提交数据,导致每次读取数据不一致
    REPEATABLE READ 可重复读,多次读取数据都一致,产生幻读,即读取过程中,即使有其它提交的事务修改数据,仍只能读取到未修改前的旧数据。
                    此为MySQL默认设置
    SERIALIZABILE 可串行化,未提交的读事务阻塞修改事务,或者未提交的修改事务阻塞读事务。导致并发性能差
    MVCC: 多版本并发控制,和事务级别相关
    
    事务隔离级别.jpg

    指定事务隔离级别:

    服务器变量tx_isolation指定,默认为REPEATABLE-READ,可在GLOBAL和
    SESSION级进行设置
    SET tx_isolation=''
        READ-UNCOMMITTED
        READ-COMMITTED
        REPEATABLE-READ
        SERIALIZABLE
    服务器选项中指定
    vim /etc/my.cnf
        [mysqld]
        transaction-isolation=SERIALIZABLE   注意这个和服务器变量名不一样
    

    相关文章

      网友评论

        本文标题:9.MySQL中的事务

        本文链接:https://www.haomeiwen.com/subject/ddswkktx.html