图书介绍
PostgreSQL指南PDF|Epub|txt|kindle电子书版本网盘下载
- (日)铃木启修(Hironobu Suzuki)著 著
- 出版社: 北京:电子工业出版社
- ISBN:9787121357091
- 出版时间:2019
- 标注页数:232页
- 文件大小:79MB
- 文件页数:248页
- 主题词:关系数据库系统
PDF下载
下载说明
PostgreSQL指南PDF格式电子书版下载
下载的文件为RAR压缩包。需要使用解压软件进行解压得到PDF格式图书。建议使用BT下载工具Free Download Manager进行下载,简称FDM(免费,没有广告,支持多平台)。本站资源全部打包为BT种子。所以需要使用专业的BT下载软件进行下载。如BitComet qBittorrent uTorrent等BT下载工具。迅雷目前由于本站不是热门资源。不推荐使用!后期资源热门了。安装了迅雷也可以迅雷进行下载!
(文件页数 要大于 标注页数,上中下等多册电子书除外)
注意:本站所有压缩包均有解压码: 点击下载压缩包解压工具
图书目录
第1章 数据库集簇、数据库和数据表1
1.1 数据库集簇的逻辑结构1
1.2 数据库集簇的物理结构2
1.2.1 数据库集簇的布局3
1.2.2 数据库布局4
1.2.3 表和索引相关文件的布局5
1.2.4 PostgreSQL中表空间的布局7
1.3 堆表文件的内部布局8
1.4 读写元组的方式11
1.4.1 写入堆元组11
1.4.2 读取堆元组12
第2章 进程和内存架构14
2.1 进程架构14
2.1.1 Postgres服务器进程15
2.1.2 后端进程15
2.1.3 后台进程16
2.2 内存架构17
2.2.1 本地内存区域17
2.2.2 共享内存区域18
第3章 查询处理19
3.1 概览20
3.1.1 解析器20
3.1.2 分析器22
3.1.3 重写器24
3.1.4 计划器与执行器25
3.2 单表查询的代价估计27
3.2.1 顺序扫描28
3.2.2 索引扫描29
3.2.3 排序36
3.3 创建单表查询的计划树38
3.3.1 预处理41
3.3.2 找出代价最小的访问路径42
3.3.3 创建计划树51
3.4 执行器如何工作55
3.5 连接57
3.5.1 嵌套循环连接57
3.5.2 归并连接63
3.5.3 散列连接67
3.5.4 连接访问路径与连接节点73
3.6 创建多表查询计划树76
3.6.1 预处理76
3.6.2 获取代价最小的路径77
3.6.3 获取三表查询代价最小的路径81
参考文献83
第4章 外部数据包装器84
4.1 概述85
4.1.1 创建一棵查询树86
4.1.2 连接至远程服务器86
4.1.3 使用EXPLAIN命令创建计划树(可选)87
4.1.4 逆解析87
4.1.5 发送SQL命令并接收结果88
4.2 postgres_fdw的工作原理90
4.2.1 多表查询91
4.2.2 排序操作97
4.2.3 聚合函数98
第5章 并发控制101
5.1 事务标识103
5.2 元组结构104
5.3 元组的增、删、改106
5.3.1 插入106
5.3.2 删除107
5.3.3 更新108
5.3.4 空闲空间映射109
5.4 提交日志110
5.4.1 事务状态110
5.4.2 提交日志如何工作110
5.4.3 提交日志的维护111
5.5 事务快照111
5.6 可见性检查规则114
5.6.1 t_xmin的状态为ABORTED115
5.6.2 t_xmin的状态为IN_PROGRESS115
5.6.3 t_xmin的状态为COMMITTED116
5.7 可见性检查118
5.7.1 可见性检查的过程118
5.7.2 PostgreSQL可重复读等级中的幻读122
5.8 防止丢失更新122
5.8.1 并发UPDATE命令的行为123
5.8.2 例子125
5.9 可串行化快照隔离127
5.9.1 SSI实现的基本策略127
5.9.2 PostgreSQL的SSI实现128
5.9.3 SSI的原理129
5.9.4 假阳性的串行化异常132
5.10 需要的维护进程134
参考文献136
第6章 清理过程137
6.1 并发清理概述138
6.1.1 第一部分139
6.1.2 第二部分140
6.1.3 第三部分140
6.1.4 后续处理141
6.2 可见性映射141
6.3 冻结过程142
6.3.1 惰性模式142
6.3.2 迫切模式143
6.3.3 改进迫切模式中的冻结过程146
6.4 移除不必要的CLOG文件147
6.5 自动清理守护进程148
6.6 完整清理148
第7章 堆内元组和仅索引扫描153
7.1 堆内元组153
7.1.1 没有HOT时的行更新153
7.1.2 HOT如何工作154
7.2 仅索引扫描157
第8章 缓冲区管理器160
8.1 概览161
8.2 缓冲区管理器的结构163
8.2.1 缓冲表164
8.2.2 缓冲区描述符165
8.2.3 缓冲区描述符层167
8.2.4 缓冲池169
8.3 缓冲区管理器锁169
8.3.1 缓冲表锁170
8.3.2 缓冲区描述符相关的锁170
8.4 缓冲区管理器的工作原理174
8.4.1 访问存储在缓冲池中的页面174
8.4.2 将页面从存储加载到空槽175
8.4.3 将页面从存储加载到受害者缓冲池槽176
8.4.4 页面替换算法:时钟扫描178
8.5 环形缓冲区180
8.6 脏页刷盘181
第9章 WAL182
9.1 概述183
9.1.1 没有WAL的插入操作183
9.1.2 插入操作与数据库恢复184
9.1.3 整页写入186
9.2 事务日志与WAL段文件188
9.3 WAL段文件的内部布局190
9.4 WAL记录的内部布局191
9.4.1 WAL记录首部部分191
9.4.2 XLOG记录的数据部分(9.4 及更低版本)193
9.4.3 XLOG记录的数据部分(9.5 及更高版本)196
9.5 WAL记录的写入200
9.6 WAL写入进程203
9.7 PostgreSQL中的检查点进程203
9.7.1 检查点进程概述204
9.7.2 pg_crontrol文件205
9.8 PostgreSQL中的数据库恢复206
9.9 WAL段文件管理209
9.9.1 WAL段切换209
9.9.2 WAL段管理(9.5 及更高版本)209
9.9.3 WAL段管理(9.4 及更低版本)211
9.10 持续归档与归档日志212
第10章 基础备份与时间点恢复214
10.1 基础备份215
10.1.1 pg_start_backup215
10.1.2 pg_stop__backup217
10.2 时间点恢复(PITR)的工作原理217
10.3 时间线与时间线历史文件220
10.3.1 时间线标识220
10.3.2 时间线历史文件221
10.4 时间点恢复与时间线历史文件222
第11章 流复制224
11.1 流复制的启动225
11.2 如何实施流复制227
11.2.1 主从间的通信227
11.2.2 发生故障时的行为229
11.3 管理多个备库229
11.3.1 同步优先级与同步状态229
11.3.2 主库如何管理多个备库230
11.3.3 发生故障时的行为231
11.4 备库的故障检测232