第1章 Oracle 12c数据库软件安装 1
1.1 Oracle数据库安装 2
1.1.1 操作系统镜像文件下载 2
1.1.2 操作系统配置方法 6
1.1.3 Oracle数据库软件安装程序下载方法 9
1.1.4 基础环境配置检查 10
1.1.5 运行安装程序 10
1.1.6 配置安全更新 10
1.1.7 安装选项 11
1.1.8 服务器类别 12
1.1.9 Oracle安装用户 13
1.1.10 安装位置 14
1.1.11 先决条件、概要、安装产品 15
1.2 小结 16
第2章 Oracle数据库基本概念 17
2.1 关于关系数据库 17
2.2 Oracle数据库的发展史 18
2.3 认识数据库对象 19
2.4 表 20
2.4.1 堆表 20
2.4.2 临时表 23
2.4.3 索引组织表 24
2.4.4 集群表 24
2.4.5 分区表 25
2.5 索引 28
2.5.1 索引的使用 30
2.5.2 索引建立的原则 31
2.6 视图 31
2.6.1 普通枧图 32
2.6.2 物化视图 32
2.6.3 对象视图 32
2.7 小结 33
第3章 Oracle数据库体系结构 34
3.1 体系结构概述 34
3.2 Oracle数据库的连接 35
3.3 实例内存区 36
3.3.1 数据库高速缓冲区 37
3.3.2 日志缓冲区 38
3.3.3 共享池 39
3.3.4 Java池和流池 39
3.4 后台进程 40
3.4.1 进程监视器 41
3.4.2 系统监视器 41
3.4.3 检查点管理进程 42
3.4.4 数据库写进程 43
3.4.5 日志写进程 43
3.4.6 管理监控进程 44
3.4.7 归档进程 44
3.5 物理结构 48
3.5.1 数据文件 48
3.5.2 日志文件 48
3.5.3 控制文件 49
3.5.4 参数文件 49
3.5.5 其他文件 49
3.6 逻辑结构 49
3.6.1 表空间 50
3.6.2 段 51
3.6.3 数据区 51
3.6.4 数据块 52
3.7 小结 52
第4章 数据库自动存储管理 53
4.1 ASM综述 53
4.2 ASM体系结构 54
4.3 ASM中存储的概念 55
4.4 ASM磁盘组 56
4.5 磁盘组的管理 58
4.6 ASM磁盘组兼容性 60
4.7 ASMCMD程序 61
4.8 小结 62
第5章 通过配置实现数据库可恢复 63
5.1 备份恢复任务 63
5.2 Oracle的备份恢复方案 64
5.3 配置数据库使其可恢复 64
5.4 使用快速恢复区 67
5.5 配置备份规范 69
5.5.1 备份目标 70
5.5.2 配置RMAN的永久性设置 70
5.5.3 控制文件自动备份 70
5.5.4 配置设备和分配通道 71
5.5.5 配置备份优化 72
5.6 小结 73
第6章 备份与恢复 74
6.1 使用RMAN创建备份 74
6.1.1 创建映像副本 75
6.1.2 创建整体数据库备份 75
6.1.3 归档备份 77
6.1.4 RMAN备份类型 78
6.1.5 压缩备份和加密备份 81
6.2 使用RMAN执行恢复 82
6.2.1 完全恢复与不完全恢复 83
6.2.2 RMAN演示1:在丢失了所有控制文件副本后进行恢复 85
6.2.3 RMAN演示2:在丢失了重做日志组后进行恢复 89
6.2.4 RMAN演示3:恢复映像副本 91
6.2.5 RMAN演示4:执行快速恢复 96
6.2.6 RMAN演示5:克隆数据库 102
6.3 小结 114
第7章 管理数据库性能 115
7.1 几个与性能管理相关的概念 116
7.1.1 性能优化数据 116
7.1.2 优化统计信息收集 116
7.1.3 Oracle等待事件 117
7.1.4 实例统计信息 118
7.1.5 与会话和服务有关的统计信息 119
7.2 Oracle数据库优化方案 119
7.2.1 内存优化 120
7.2.2 IO优化 126
7.2.3 如何检查Oracle数据库的性能 145
7.2.4 问题处理方法与思路 153
7.3 寻找问题根源 154
7.3.1 System Event事件 154
7.3.2 Session Event事件 155
7.3.3 Session Wait 155
7.3.4 应用优化 155
7.3.5 内存调优 155
7.3.6 I/O优化 156
7.3.7 竞争优化 157
7.4 小结 157
第8章 Oracle常用管理工具 158
8.1 SQLPlus工具及其使用 158
8.1.1 启动SQLPlus 158
8.1.2 关闭SQLPlus 159
8.1.3 设置变量 159
8.1.4 设置SQLPlus环境参数 160
8.1.5 设置SQLPlus配置文件 161
8.1.6 编辑执行SQL语句 161
8.1.7 编辑执行SQLPlus命令 162
8.2 常用的SQLPlus命令 163
8.2.1 连接数据库 163
8.2.2 格式化命令 163
8.2.3 SET命令 166
8.3 小结 167
第9章 Oracle 12c多租户功能 168
9.1 Oracle 12c版本新特性 168
9.2 什么是多租户功能 172
9.2.1 Oracle 12c多租户功能简介 172
9.2.2 容器数据库介绍 172
9.2.3 多租户功能的优势 173
9.2.4 创建多租户数据库 173
9.2.5 基本管理 180
9.3 小结 185
第10章 SQL基础 186
10.1 SQL语句分类 186
10.2 查询语句 187
10.2.1 SELECT查询语句 187
10.2.2 SELECT DISTINCT语句 188
10.2.3 WHERE子句 189
10.2.4 AND和OR运算符 190
10.2.5 ORDER BY语句用于对结果集进行排序 192
10.2.6 BETWEEN操作符 193
10.2.7 LIKE操作符 195
10.3 数据操作语句 196
10.3.1 INSERT INTO语句 196
10.3.2 UPDATE语句 197
10.3.3 DELETE语句 198
10.4 连接查询语句 199
10.4.1 JOIN和KEY的作用 199
10.4.2 INNER JOIN关键字 201
10.4.3 LEFT JOIN关键字 202
10.4.4 RIGHT JOIN关键字 203
10.4.5 FULL JOIN关键字 203
10.4.6 UNION操作符 204
10.5 常见函数 206
10.5.1 COUNT()函数 206
10.5.2 SUM()函数 207
10.5.3 MAX()函数 207
10.5.4 MIN()函数 208
10.5.5 GROUP BY语句 208
10.6 小结 209
第11章 PL/SQL基础 210
11.1 PL/SQL的优点 210
11.2 PL/SQL块结构 211
11.3 PL/SQL块的命名和匿名 212
11.3.1 函数 212
11.3.2 过程 212
11.3.3 包 213
11.3.4 触发器 213
11.3.5 声明变量 214
11.3.6 给变量赋值 214
11.3.7 常量 215
11.3.8 标量 215
11.3.9 操作符 216
11.3.10 执行部分 217
11.3.11 执行一个PL/SQL块 220
11.3.12 控制结构 221
11.4 实战PL/SQL举例 223
11.4.1 构造一个简单的PL/SQL块 223
11.4.2 PL/SQL块接收用户的输入信息 223
11.4.3 查询 225
11.4.4 LOOP循环 226
11.4.5 WHILE循环 227
11.4.6 FOR循环 228
11.4.7 IF语句 229
11.4.8 IF…ELSE语句 229
11.4.9 IF…ELSIF…ELSE语句 230
11.5 小结 230
第12章 Oracle RAC架构安装与部署 231
12.1 软件和硬件准备 232
12.2 安装前的检查和配置 232
12.2.1 检查操作系统环境 232
12.2.2 检查系统软件套件 233
12.2.3 关闭服务(防火墙) 234
12.2.4 调整系统参数 234
12.2.5 修改hostname 236
12.2.6 配置hosts 236
12.2.7 创建用户和组 236
12.2.8 挂载安装目录 237
12.2.9 创建安装目录 237
12.2.10 设置用户环境变量 237
12.2.11 配置共享存储 238
12.2.12 禁用Transparent HugePages 240
12.2.13 配置NTP服务 241
12.2.14 其他节点重复步骤 242
12.2.15 互信配置 242
12.3 GRID安装 243
12.3.1 安装前预先检查 243
12.3.2 cvuqdisk包安装(两个节点都安装) 243
12.4 开始安装 244
12.5 创建ASM磁盘组 254
12.6 数据库软件安装 256
12.7 建库 262
12.8 安装PSU 271
12.8.1 解压、授权 272
12.8.2 命令 272
12.8.3 过程输出 272
12.9 卸载 280
12.9.1 卸载Database Software 280
12.9.2 卸载Grid Infrastructure 281
12.10 小结 281