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 ,做所有保存点都将被忽视