Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
wushizhenking
CS-Notes
提交
e08c1f0e
C
CS-Notes
项目概览
wushizhenking
/
CS-Notes
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
CS-Notes
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
e08c1f0e
编写于
8月 09, 2018
作者:
C
CyC2018
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
auto commit
上级
02f03861
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
8 addition
and
22 deletion
+8
-22
notes/数据库系统原理.md
notes/数据库系统原理.md
+8
-22
未找到文件。
notes/数据库系统原理.md
浏览文件 @
e08c1f0e
...
...
@@ -383,13 +383,13 @@ MVCC 不能解决幻读的问题,Next-Key Locks 就是为了解决这个问题
## Record Locks
锁定
的对象是记录
的索引,而不是记录本身。
锁定
一个记录上
的索引,而不是记录本身。
如果表没有设置索引,InnoDB 会自动在主键上创建隐藏的聚集索引,因此 Record Locks 依然可以使用。
## Gap Locks
锁定
一个范围内的索引,
例如当一个事务执行以下语句,其它事务就不能在 t.c 中插入 15。
锁定
索引之间的间隙,但是不包含索引本身。
例如当一个事务执行以下语句,其它事务就不能在 t.c 中插入 15。
```
sql
SELECT
c
FROM
t
WHERE
c
BETWEEN
10
and
20
FOR
UPDATE
;
...
...
@@ -397,28 +397,14 @@ SELECT c FROM t WHERE c BETWEEN 10 and 20 FOR UPDATE;
## Next-Key Locks
它是 Record Locks 和 Gap Locks 的结合,不仅锁定一个记录
,也锁定范围内的索引。在 user 中有以下记录
:
它是 Record Locks 和 Gap Locks 的结合,不仅锁定一个记录
上的索引,也锁定范围内的索引。例如一个索引包含以下值:10, 11, 13, and 20,那么就需要锁定以下区间
:
```
sql
|
id
|
last_name
|
first_name
|
age
|
|
------|-------------|--------------|-------|
|
4
|
stark
|
tony
|
21
|
|
1
|
tom
|
hiddleston
|
30
|
|
3
|
morgan
|
freeman
|
40
|
|
5
|
jeff
|
dean
|
50
|
|
2
|
donald
|
trump
|
80
|
+
------|-------------|--------------|-------+
```
那么就需要锁定以下范围:
```
sql
(
-
∞
,
21
]
(
21
,
30
]
(
30
,
40
]
(
40
,
50
]
(
50
,
80
]
(
80
,
∞
)
(
negative
infinity
,
10
]
(
10
,
11
]
(
11
,
13
]
(
13
,
20
]
(
20
,
positive
infinity
)
```
# 七、关系数据库设计理论
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录