MySQL-第十二章 事务

12.1 多用户数据库

12.1.1 锁

12.1.1.1 定义

数据库服务器用来控制并行数据的一种机制
即,当数据库被锁定时,想要执行读操作或者写操作都需要等到锁被释放

12.1.1.2 两种类型

类型一:

  • 读操作需要申请读锁, 写操作需要申请写锁
  • 可以同时进行读锁
  • 写锁只能一个一个进行,并且拒绝读请求

缺点:
并行多个读操作,写操作等待时间较长

类型二:

  • 读操作不受控,写操作需要申请
  • 版本控制:读操作从查询到结束操作,数据不会被改变,白痴一致的数据视图

缺点:在修改数据时,存在长期运行的查询操作

11.2.1 锁的粒度

在这里插入图片描述

  • 表锁:
    优点:需要较少的 ‘ 薄记 ’ 就可以锁定整个表,
    缺点:但是修改表等待时间较长

  • 行锁:
    缺点::需要较多的‘ 薄记 ’ ,
    优点:但是允许多个用户在同一张表上进行修改

12.2 什么是事务

原子性:
当多条SQL语句并发执行,要么全部执行,要么一条也不执行

事务:
当执行一个程序时,先启动一个事务,然后发起SQL语句,

  • 当全部执行完毕后,发出commit,结束事务,
  • 否则,发出rollback,撤销服务器字十五开始的所有变化
  • 当服务器既没有返回commit 也没有返回rollback, 服务器卡机, 事务会再重新上线并进行回滚rollback

12.2.1 启动事务

  • 显式启动 :使用strat 命令, sql sever, mysql
  • 隐式启动:数据库服务器自动提交,oracle

12.2.2 结束事务

必须显式结束

12.2.2.1正常结束:
  • 提交commit命令 ,正常执行事务
  • 提交rollback命令,出现意外返回事务起点
12.2.2.2 意外出发结束事务:

在这里插入图片描述

  • 死锁
    两个事务意外连接形成循环,一个表的结束成了另一表的开始
    必须选择一个事务rollback是其他事务进行下去
  • 解决
    按顺序访问数据资源

12.2.3 事务保存点

事务需要rollback时,不想让所有的改变都被撤销,则需要创建一个或多个保存点,rollback到事务的特定位置而不是起始状态

  • 保存点,必须拥有一个名字: savepoint xx
  • rollback时,只需执行命令 : rollback to savepoint xx

在这里插入图片描述

  • 若没有commit,创建的保存点除了名字,没有进行保存实际东西

  • 若没有rollback to ,做所有保存点都将被忽视

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值