DAY03

事务

  1. 事务 保证 一组操作全部成功,或者失败。
  2. 事务是引擎层实现的,MYISAM不支持事务,InnoDB支持事务
  3. 事务的4个特性,ACID(Atomicity、Consistency、Isolation、Durability,即原子性、一致性、隔离性、持久性)
  4. 当数据库上有多个事务同时执行时候,就会出现脏读不可重复读、幻读的问题。所以有个隔离级别的概念`
  5. 事务的隔离级别:

    读未提交(read uncommitted):一个事务未提交,他的更变就可以被其他事务看到
    读提交(read committed):一个事务提交之后,他所做的变更才会被其他事务看到
    可重复度(repeatable read):一个事务执行过程中,看到的数据是一致的(基于视图)
    串行化(serializable):对应一个记录会加读写锁,出现冲突的时候,后访问的事务必须等前一个事务执行完才可以继续执行。

  6. 事务隔离的实现。数据库会创建视图,访问的时候以视图的结果为准。

    可重复读:视图是在事务启动时创建的,整个事务期间都在用这个视图。所以看不见其他事务的修改。
    读提交:在每个sql语句开始执行的时候创建。
    读未提交:没有视图概念,直接返回记录上的最新值。

每条记录在更新的时候都会同时记录一条回滚操作,同一条记录在系统中可以存在多个版本,就是数据库的多版本并发控制(MVCC),当没有事务需要这些回滚日志的时候,就会被删除

  1. 尽量不要使用长事务。长事务意味着存在很老的视图,导致占据大量的空间。在5.5版本之前,回滚日志是和数据字典一起放在ibdata文件里,即使长事务最终提交,回滚段被清理,文件也不会变小。我见过数据只有 20GB,而回滚段有 200GB 的库。最终只好为了清理回滚段,重建整个库

  2. 一个数据版本,对于一个事务视图来说,除了自己的更新总是可见以外,有三种情况:

    1. 版本未提交,不可见;
    2. 版本已提交,但是是在视图创建后提交的,不可见;
    3. 版本已提交,而且是在视图创建前提交的,可见。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值