• ADADADADAD

    1-5 大事务带来的问题[ mysql数据库 ]

    mysql数据库 时间:2024-12-25 09:58:24

    作者:文/会员上传

    简介:

    当系统崩溃后,发现有没有提交的事务,有的话会回滚操作(1)在第一个 窗口begin; select from t where id < 7; ->1 3 5(2)在第二个 窗口begin; insert intotvalues(2); commit;

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。





    当系统崩溃后,发现有没有提交的事务,有的话会回滚操作




    (1)在第一个 窗口begin; select from t where id < 7; ->1 3 5
    (2)在第二个 窗口begin; insert intotvalues(2); commit;
    (3)在第一个 窗口select
    from t whereid < 7; ->135commit;把当前事务隔离级别改下
    set sesstion tx_isolation='read-committed';(读已提交)
    select from t where id < 7;1 3 5 2

    (4)在第二个 窗口 begin;insert into t values(4); commit;
    (5)在第一个 窗口 select
    from t where id < 7; 13 5 24

    第四种 隔离级别
    可串行化serializable最高隔离级别 ,读取的每一行数据都加锁,会导致大量的锁超时,所以很少使用这个隔离级别,隔离性由低到高,并发性由高到低。

    innodb 默认隔离级别是 可重复读

    什么是大事务

    定义运行时间比较长 ,操作的数据比较多的事务
    风险 :
    1 锁定太多的数据,造成大量的阻塞和锁超时,
    2回滚时所需要时间比较长,执行时间长,容易造成主从延迟,
    3如果主库的事务执行了几个小时后再提交,才会写入binlog 里,从库才会读binlog 日志 才开始同步
    4innodb 是行级锁,当涉及所有记录时,就会相当于整个表锁住,

    如何处理大事务

    1避免一次处理太多的数据
    2移除不必要在事务中的select 操作

    1-5 大事务带来的问题.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: mysql事务