内容简介 · · · · · ·
《Oracle数据库精讲与疑难解析(第2版)(畅销书)(升级版)》是一本毫无保留的Oracle学习宝典。通过作者历时3年的写作,《Oracle数据库精讲与疑难解析(第2版)(畅销书)(升级版)》介绍了Oracle的安装及卸载、数据库的启动/关闭、表空间和数据文件的管理、Oracle网络管理、口令文件管理、内存管理、进程管理、用户管理、数据的导入/导出、备份与恢复、模式对象的管理,以及应用程序开发等相关知识。《Oracle数据库精讲与疑难解析(第2版)(畅销书)(升级版)》旨在向读者解答使用Oracle中遇到的疑难问题,并展示管理Oracle的大量技巧。
作者简介 · · · · · ·
赵振平
生于20世纪末中国西南的一个边陲小镇。21世纪初,那是一个IT业动荡的日子,多少网站林立,又有多少网站倒闭;多少英雄冲锋,又有多少豪杰流泪。华尔街金融巨子们疯狂涌入IT业,克林顿总统先生的“信息高速公路”政策,为我们描绘了IT业的宏伟蓝图,不知天有多高、地有多厚的我们,被卷入了全球IT业的激流中。但是,在激流中有过倒下,在激流中有过彷徨.....在彷徨中思考未来。于是公元2001年,我正式主攻数据库和数据仓库。开始的岁月,Sybase、Oracle与SQL Server三座大山压得我无法喘息,从不低头的我们仍然要继续前行的路。N年以后,我们越过了Sybase、Oracle、SQL Server、MySQL、DB2这几座大山。但是,中国至今在数据库领域还没有太多的话语权,路还很远,很长......还需要更多的人与我们一起努力!!
目录 · · · · · ·
第1篇 创建属于自己的Oracle数据库
第1章 认识Oracle的世界——Oracle的体系结构 2
1.1 Oracle的发家史 2
1.2 数据库 3
1.3 数据库管理系统(DBMS) 3
1.4 关系数据库的概念(RDBMS) 3
· · · · · · (更多)
第1章 认识Oracle的世界——Oracle的体系结构 2
1.1 Oracle的发家史 2
1.2 数据库 3
1.3 数据库管理系统(DBMS) 3
1.4 关系数据库的概念(RDBMS) 3
· · · · · · (更多)
第1篇 创建属于自己的Oracle数据库
第1章 认识Oracle的世界——Oracle的体系结构 2
1.1 Oracle的发家史 2
1.2 数据库 3
1.3 数据库管理系统(DBMS) 3
1.4 关系数据库的概念(RDBMS) 3
1.4.1 关系数据库模型 4
1.4.2 表 5
1.5 Oracle的总体框架结构 5
1.5.1 Oracle实例(Oracle Instance) 6
1.5.2 Oracle的存储结构 7
1.6 数据字典(Data Dictionary) 8
1.6.1 数据字典概述 8
1.6.2 数据字典的结构 8
1.6.3 数据字典的使用 8
第2章 迈出第1步——Oracle的安装/卸载 10
2.1 Oracle的安装 10
2.1.1 Oracle安装的几个概念 10
2.1.2 Oracle 11g R2(11.2)的安装——Windows篇 12
2.1.3 Oracle 11g RAC的安装——Linux篇 27
2.1.4 Oracle安装疑难解析 98
2.2 Oracle的卸载 123
2.2.1 Oracle完全卸载——Windows篇 123
2.2.2 Oracle完全卸载——UNIX篇 128
第3章 有米之炊——数据库的创建与删除 137
3.1 创建数据库 137
3.1.1 数据库创建概述 137
3.1.2 Solaris下用DBCA创建数据库 139
3.1.3 DIY——Solaris下手工创建数据库 149
3.1.4 数据库创建疑难解析 155
3.2 删除数据库 164
3.2.1 数据库删除概述 164
3.2.2 数据库删除——手工篇 165
3.2.3 数据库删除——DBCA篇 165
第2篇 网络管理
第4章 Oracle网络管理并不难 168
4.1 Oracle网络体系结构 168
4.1.1 Oracle应用的几种网络结构 168
4.1.2 Oracle Net 170
4.1.3 OSI模型 170
4.1.4 Oracle Net的堆栈结构 171
4.1.5 Oracle监听器 172
4.1.6 连接描述符(connect identifier) 173
4.1.7 网络服务名(Net Service Name) 174
4.1.8 命名方法 176
4.1.9 配置Oracle网络的工具 176
4.2 Oracle网络管理实务 176
4.2.1 Oracle网络服务器端配置 176
4.2.2 Oracle网络客户端配置 182
4.3 Oracle网络管理疑难解析 187
4.3.1 Oracle网络服务器端配置疑难解析 187
4.3.2 Oracle网络客户端配置疑难解析 194
4.3.3 Oracle网络与防火墙(Firewall) 215
第3篇 系统管理
第5章 系统管家婆——SQL*Plus的使用 222
5.1 系统管理工具SQL*Plus 222
5.2 SQL缓冲区(SQL Buffer) 223
5.3 SQL*Plus的环境配置 223
5.3.1 SQL*Plus的环境变量 223
5.3.2 SQL*Plus站点配置文件(Site Profile) 223
5.3.3 SQL*Plus用户配置文件(User Profile) 223
5.4 SQL*Plus的启动 223
5.5 SQL*Plus专有命令介绍 225
5.5.1 登录、注销命令 225
5.5.2 编辑命令 225
5.5.3 其他有用的SQL*Plus命令 227
5.6 SQL*Plus实务与疑难解析 228
第6章 有始有终——数据库的启动与关闭 247
6.1 数据库启动 247
6.1.1 数据库启动原理 247
6.1.2 数据库启动实务 248
6.1.3 数据库启动疑难解析 261
6.2 数据库关闭 284
6.2.1 数据库关闭原理 284
6.2.2 数据库的关闭(SHUTDOWN)实务 284
6.2.3 数据库关闭疑难解析 288
第7章 理清两个模式问题——专有/共享服务器模式 292
7.1 理解专有服务器模式 292
7.2 共享服务器模式原理 293
7.2.1 共享服务器模式的架构 293
7.2.2 监听器和调度进程的关系 293
7.2.3 请求队列(Request Queue)/响应队列(Response Queue) 294
7.2.4 调度进程(Dispatcher Processes,Dnnn) 294
7.2.5 共享服务器进程(Shared Server Processes,Snnn) 294
7.3 共享服务器模式实务 294
7.4 共享服务器模式疑难解析 305
第8章 掌握两个管理问题——表空间和数据文件的管理 317
8.1 数据库存储结构 317
8.1.1 物理结构 317
8.1.2 逻辑结构 320
8.2 深刻理解表空间 327
8.2.1 大文件表空间 327
8.2.2 系统表空间 327
8.2.3 辅助表空间 327
8.2.4 回滚表空间(Undo Tablespace) 327
8.2.5 临时表空间 330
8.2.6 表空间中区的管理方式 331
8.2.7 表空间中段的管理方式 332
8.2.8 非标准块表空间 333
8.2.9 表空间的离线(Offline)与在线(Online) 333
8.2.10 只读表空间(Read-Only Tablespace) 333
8.3 深刻理解数据文件 334
8.3.1 数据文件的内容 334
8.3.2 数据文件的尺寸(Size) 334
8.3.3 离线数据文件 334
8.3.4 临时数据文件(Temporary Datafiles) 334
8.4 表空间管理实务与疑难解析 335
8.4.1 永久表空间管理 335
8.4.2 临时表空间管理实务与疑难解析 366
8.4.3 回滚表空间管理实务与疑难解析 373
8.5 数据文件管理实务与疑难解析 379
8.5.1 数据文件管理实务 379
8.5.2 数据文件管理疑难解析 388
第9章 进程管理 390
9.1 Oracle进程简介 390
9.2 用户进程 391
9.3 Oracle进程 391
9.3.1 服务器进程 391
9.3.2 后台进程 391
9.4 进程综合管理实务与疑难解析 395
9.5 会话管理实务与疑难解析 403
第10章 内存管理 408
10.1 Oracle内存结构简介 408
10.2 系统全局区(SGA) 409
10.2.1 SGA简介 410
10.2.2 SGA组成 411
10.3 程序全局区(PGA) 414
10.3.1 私有SQL区 414
10.3.2 SQL工作区 415
10.3.3 用户全局区 415
10.4 软件代码区 415
10.5 管理Oracle内存的方式 415
10.5.1 PGA自动管理 415
10.5.2 SGA自动管理 416
10.5.3 自动内存管理 416
10.6 内存管理实务与疑难解析 416
第11章 用户管理 439
11.1 用户验证 440
11.1.1 口令认证 440
11.1.2 外部认证 440
11.1.3 全局认证 441
11.2 Oracle的安全大门——权限(Privileges) 441
11.2.1 系统权限 441
11.2.2 对象权限 444
11.3 使权限管理变得更加容易——角色(Role) 445
11.4 限制用户的资源消耗——资源限制文件(Profile) 446
11.4.1 资源限制的级别 447
11.4.2 限制资源的参数 447
11.5 用户与权限管理实务与疑难解析 448
11.5.1 用户管理实务与疑难解析 448
11.5.2 权限管理实务与疑难解析 453
11.5.3 角色管理实务与疑难解析 457
11.5.4 资源限制文件管理实务与疑难解析 463
第4篇 移动数据库
第12章 数据导出 468
12.1 数据导出方法介绍 468
12.1.1 Oracle最新导出工具——Data Pump Export 468
12.1.2 Oracle原来的导出工具——Export 468
12.2 数据导出实务 471
12.3 数据导出疑难解析 489
第13章 数据导入 508
13.1 数据导入方法介绍 508
13.1.1 Oracle最新导入工具——Data Pump Import 508
13.1.2 Oracle以前的导入方法——Import 508
13.2 数据导入实务 510
13.3 数据导入疑难解析 530
第5篇 Oracle文件管理
第14章 重中之重——控制文件的管理 544
14.1 控制文件的概念 544
14.2 控制文件管理实务与疑难解析 545
第15章 成为数据库的最高统治者——口令文件(Password File)管理 555
15.1 超级用户权限(SYSDBA、SYSOPER)介绍 555
15.2 口令文件的基本概念 556
15.3 启用口令文件认证 557
15.4 口令文件管理实务与疑难解析 558
第16章 联机日志文件管理 571
16.1 联机日志文件的概念 571
16.1.1 联机日志文件的内容 571
16.1.2 联机日志文件的循环利用 572
16.2 联机日志文件管理实务与疑难解析 572
第17章 参数文件(PFILE/SPFILE)管理 584
17.1 参数文件的基本概念 584
17.2 初始化参数文件 585
17.3 服务器参数文件 585
17.4 初始化参数的修改 585
17.5 参数管理实务与疑难解析 586
第6篇 Oracle高级专题
第18章 全球应用——分布式数据库疑难攻略 594
18.1 分布式数据库系统的概念 594
18.1.1 同构分布式数据库系统 595
18.1.2 异构分布式数据库系统 595
18.1.3 数据库链接(Database Link) 595
18.2 分布式数据库管理实务与疑难解析 595
第19章 并不陌生的问题——裸设备 603
19.1 裸设备的概念 603
19.2 裸设备管理实务与疑难解析 604
第7篇 数据库备份/恢复
第20章 备份/恢复之基石——归档(Archivelog)管理 612
20.1 归档的基本概念 612
20.1.1 非归档模式 612
20.1.2 归档模式 613
20.1.3 归档路径 613
20.2 归档管理实务与疑难解析 614
第21章 必行之举——数据库备份 636
21.1 理解数据库备份 636
21.1.1 数据库失败的种类 637
21.1.2 备份和恢复的解决方案 637
21.1.3 备份和恢复的物理结构 638
21.1.4 备份的类型 638
21.1.5 执行用户管理的备份 638
21.2 恢复管理器(RMAN) 639
21.2.1 通道 640
21.2.2 备份集的维护 640
21.2.3 RMAN资料库 642
21.2.4 RMAN的使用 643
21.3 数据库备份实务与疑难解析 643
21.4 恢复目录管理实务与疑难解析 665
第22章 失而复得——数据库恢复 673
22.1 数据库恢复 673
22.1.1 实例恢复 673
22.1.2 介质恢复 674
22.1.3 用户错误(User Error)的恢复 675
22.2 数据库闪回(Flashback Database) 676
22.3 用户管理的恢复(User-managed Recovery) 676
22.4 联机日志文件丢失的恢复 677
22.5 控制文件损坏的恢复 689
22.6 数据文件损坏的恢复 700
22.7 表的恢复(用户错误的恢复) 711
第8篇 Oracle程序设计
第23章 数据库通用语言——SQL语句 742
23.1 结构化查询语言简介 742
23.2 SELECT语句 743
23.2.1 理解SELECT语句 743
23.2.2 SELECT语句使用实务与疑难解析 744
23.3 INSERT语句 754
23.3.1 理解INSERT语句 754
23.3.2 INSERT语句使用实务与疑难解析 755
23.4 UPDATE语句 761
23.4.1 理解UPDATE语句 761
23.4.2 UPDATE语句使用实务与疑难解析 761
23.5 DELETE语句 763
23.5.1 理解DELETE语句 763
23.5.2 DELETE语句的使用 763
23.6 SQL语句中,集合函数使用实务与疑难解析 766
第24章 模式对象(Schema Object)的管理 771
24.1 模式(Schema)的概念 771
24.2 模式对象管理 772
24.2.1 表(Table) 772
24.2.2 索引(Index) 790
24.2.3 外部表(External Table) 795
24.2.4 临时表(Temporary Table) 805
24.2.5 分区表(Partition Table) 809
24.2.6 聚簇(Cluster) 822
24.2.7 索引组织表(Index-Organized Table,IOT) 825
24.2.8 视图 831
24.2.9 同义词 836
24.2.10 序列 839
第25章 PL/SQL应用程序开发 844
25.1 PL/SQL简述 844
25.1.1 PL/SQL块结构 844
25.1.2 数据类型 845
25.1.3 运算符 845
25.1.4 PL/SQL语句控制结构 846
25.2 存储过程(Stored Procedure) 847
25.2.1 存储过程的基本原理 847
25.2.2 存储过程管理实务与疑难解析 847
25.3 函数(Function) 863
25.3.1 函数的基本原理 863
25.3.2 函数的管理实务与疑难解析 863
25.4 包 871
25.4.1 包的基本原理 871
25.4.2 包管理实务与疑难解析 871
25.5 触发器 878
25.5.1 触发器的基本原理 878
25.5.2 触发器管理实务与疑难解析 879
25.6 游标 899
25.6.1 游标的基本原理 899
25.6.2 游标管理实务与疑难解析 899
第9篇 内存探索
第26章 勿忘历史——Oracle内存管理的变迁 908
26.1 Oracle 内存变迁概述 908
26.2 Oracle 7 的内存管理 908
26.3 Oracle 8/8i的内存管理 909
26.4 Oracle 9i的内存管理 909
26.5 Oracle 10g的内存管理 909
26.6 Oracle 11g的内存管理 909
第27章 SGA之家——共享内存段 911
27.1 共享内存段的基本概念 911
27.2 共享内存段与内核参数 911
27.3 数据库启动与共享内存段 911
27.4 设置共享内存段 912
27.5 共享内存段的管理工具 913
27.5.1 Oracle小工具——sysresv 914
27.5.2 Oracle调试工具——oradebug 914
27.5.3 操作系统工具——ipcs(ipcrm) 915
27.6 查看内核参数对共享内存段的限制 916
27.7 共享内存段的空间使用情况 916
27.8 共享内存段与进程 917
27.9 删除共享内存段 917
第28章 内存管理效率的提升——HugePage 919
28.1 HugePage的原理 919
28.2 HugePage的配置 920
28.3 HugePage疑难解析 923
第29章 内存管理方式的巨变——内存文件系统 928
29.1 内存文件系统 928
29.2 第一阶段:传统模式(共享内存段) 929
29.3 第二阶段:新型模式(内存文件系统) 929
29.4 第三阶段:内存文件系统的设置 931
29.5 第四阶段:从“新型模式”切换到“传统模式” 931
第10篇 I/O探索
第30章 永恒的主题——I/O(同步I/O、异步I/O、直接I/O) 934
30.1 磁盘的物理结构 934
30.1.1 盘片(碟片,Platter) 934
30.1.2 磁头(Head) 934
30.1.3 磁道(Track) 934
30.1.4 扇区(Sector) 934
30.2 磁盘工作原理 935
30.2.1 寻道时间(Seek Time) 935
30.2.2 旋转延迟(Rotational Latency) 935
30.2.3 传输时间(Transfer Time) 935
30.2.4 访问时间(Access Time) 935
30.3 衡量磁盘性能的两个指标 935
30.4 I/O介绍 935
30.4.1 同步I/O 936
30.4.2 异步I/O 936
30.4.3 直接I/O 936
30.4.4 Oracle与I/O配置 936
30.4.5 异步I/O的使用 936
30.4.6 直接I/O的使用 938
30.5 随机I/O和顺序I/O 939
30.5.1 随机I/O的原理 939
30.5.2 顺序I/O的原理 940
30.6 I/O大比拼 940
30.6.1 随机I/O和顺序I/O的巨大反差 940
30.6.2 同步I/O和异步I/O的对比 940
30.6.3 直接I/O与内存的使用 941
第11篇 RAC管理
第31章 理论奠基——RAC简介 944
31.1 高可用性介绍 944
31.2 Oracle 集群 945
31.3 硬件架构 946
31.3.1 服务器介绍 946
31.3.2 共享存储介绍 946
31.3.3 网络介绍 952
31.4 软件架构 954
31.4.1 软件分层 954
31.4.2 Oracle Clusterware软件 955
31.4.3 Oracle RAC软件 962
第32章 RAC的意义——负载均衡和失败转移 963
32.1 负载均衡 963
32.1.1 负载均衡简介 963
32.1.2 客户端负载均衡 964
32.1.3 服务器端负载均衡 967
32.2 失败转移 967
32.2.1 失败转移简介 967
32.2.2 失败转移实战 967
第33章 存储的主打曲——自动存储管理(ASM) 973
33.1 ASM基本概念 973
33.1.1 ASM实例(ASM Instance) 973
33.1.2 ASM磁盘组(ASM Disk Group) 973
33.1.3 ASM文件(ASM File) 974
33.1.4 区(Extent) 974
33.1.5 镜像和失败组(Mirroring and Failure Group) 975
33.2 配置ASM实例 976
33.2.1 创建ASM实例 976
33.2.2 ASM的初始化参数 978
33.2.3 ASM实例的连接 979
33.2.4 ASM的启动 979
33.2.5 ASM的关闭 980
33.2.6 检查ASM实例的状态 981
33.3 磁盘组的管理 981
33.3.1 准备磁盘(以裸设备为例) 981
33.3.2 确保ASM能够搜索到磁盘 984
33.3.3 创建磁盘组 985
33.3.4 磁盘组的加载/卸载 987
33.3.5 在磁盘组上创建表空间 988
33.3.6 往磁盘组中添加磁盘 989
33.3.7 从磁盘组中删除磁盘 989
33.3.8 删除磁盘组 989
33.3.9 手工重平衡磁盘组中的文件 990
33.3.10 磁盘和磁盘组的信息 990
33.4 管理工具ASMCMD 991
33.5 动态卷管理器(ADVM)和集群文件系统(ACFS) 992
33.5.1 动态卷管理器(ADVM)的使用 993
33.5.2 集群文件系统(ACFS)的使用 996
33.6 ASM管理疑难解析 997
第34章 练兵场——RAC管理 1003
34.1 你必须清楚的一件情——命令运行环境 1003
34.2 集群管理工具 1003
34.3 集群的启动和关闭 1004
34.4 IP地址管理 1005
34.4.1 SCAN VIP的漂移 1005
34.4.2 检查SCAN的配置 1005
34.4.3 修改SCAN VIP和VIP 1005
34.4.4 私有IP地址的修改 1008
34.4.5 修改SCAN监听器的端口 1009
34.5 实例的管理 1010
34.5.1 实例的启动和关闭 1010
34.5.2 数据库的启动和关闭 1011
34.5.3 参数文件(PFILE、SPFILE)管理 1011
34.5.4 会话管理 1013
34.6 物理结构管理 1013
34.6.1 回滚表空间的管理 1013
34.6.2 联机重做日志的管理 1014
34.6.3 集群注册表(OCR)的管理 1015
34.6.4 Oracle本地注册表(OLR)的管理 1019
34.6.5 表决盘(Voting Disk)的管理 1020
34.6.6 集群注册表和表决盘管理实务 1022
34.7 节点管理 1029
34.7.1 节点失败那点事儿 1029
34.7.2 数据库管理模式 1030
34.7.3 删除节点 1031
34.7.4 增加节点 1042
· · · · · · (收起)
第1章 认识Oracle的世界——Oracle的体系结构 2
1.1 Oracle的发家史 2
1.2 数据库 3
1.3 数据库管理系统(DBMS) 3
1.4 关系数据库的概念(RDBMS) 3
1.4.1 关系数据库模型 4
1.4.2 表 5
1.5 Oracle的总体框架结构 5
1.5.1 Oracle实例(Oracle Instance) 6
1.5.2 Oracle的存储结构 7
1.6 数据字典(Data Dictionary) 8
1.6.1 数据字典概述 8
1.6.2 数据字典的结构 8
1.6.3 数据字典的使用 8
第2章 迈出第1步——Oracle的安装/卸载 10
2.1 Oracle的安装 10
2.1.1 Oracle安装的几个概念 10
2.1.2 Oracle 11g R2(11.2)的安装——Windows篇 12
2.1.3 Oracle 11g RAC的安装——Linux篇 27
2.1.4 Oracle安装疑难解析 98
2.2 Oracle的卸载 123
2.2.1 Oracle完全卸载——Windows篇 123
2.2.2 Oracle完全卸载——UNIX篇 128
第3章 有米之炊——数据库的创建与删除 137
3.1 创建数据库 137
3.1.1 数据库创建概述 137
3.1.2 Solaris下用DBCA创建数据库 139
3.1.3 DIY——Solaris下手工创建数据库 149
3.1.4 数据库创建疑难解析 155
3.2 删除数据库 164
3.2.1 数据库删除概述 164
3.2.2 数据库删除——手工篇 165
3.2.3 数据库删除——DBCA篇 165
第2篇 网络管理
第4章 Oracle网络管理并不难 168
4.1 Oracle网络体系结构 168
4.1.1 Oracle应用的几种网络结构 168
4.1.2 Oracle Net 170
4.1.3 OSI模型 170
4.1.4 Oracle Net的堆栈结构 171
4.1.5 Oracle监听器 172
4.1.6 连接描述符(connect identifier) 173
4.1.7 网络服务名(Net Service Name) 174
4.1.8 命名方法 176
4.1.9 配置Oracle网络的工具 176
4.2 Oracle网络管理实务 176
4.2.1 Oracle网络服务器端配置 176
4.2.2 Oracle网络客户端配置 182
4.3 Oracle网络管理疑难解析 187
4.3.1 Oracle网络服务器端配置疑难解析 187
4.3.2 Oracle网络客户端配置疑难解析 194
4.3.3 Oracle网络与防火墙(Firewall) 215
第3篇 系统管理
第5章 系统管家婆——SQL*Plus的使用 222
5.1 系统管理工具SQL*Plus 222
5.2 SQL缓冲区(SQL Buffer) 223
5.3 SQL*Plus的环境配置 223
5.3.1 SQL*Plus的环境变量 223
5.3.2 SQL*Plus站点配置文件(Site Profile) 223
5.3.3 SQL*Plus用户配置文件(User Profile) 223
5.4 SQL*Plus的启动 223
5.5 SQL*Plus专有命令介绍 225
5.5.1 登录、注销命令 225
5.5.2 编辑命令 225
5.5.3 其他有用的SQL*Plus命令 227
5.6 SQL*Plus实务与疑难解析 228
第6章 有始有终——数据库的启动与关闭 247
6.1 数据库启动 247
6.1.1 数据库启动原理 247
6.1.2 数据库启动实务 248
6.1.3 数据库启动疑难解析 261
6.2 数据库关闭 284
6.2.1 数据库关闭原理 284
6.2.2 数据库的关闭(SHUTDOWN)实务 284
6.2.3 数据库关闭疑难解析 288
第7章 理清两个模式问题——专有/共享服务器模式 292
7.1 理解专有服务器模式 292
7.2 共享服务器模式原理 293
7.2.1 共享服务器模式的架构 293
7.2.2 监听器和调度进程的关系 293
7.2.3 请求队列(Request Queue)/响应队列(Response Queue) 294
7.2.4 调度进程(Dispatcher Processes,Dnnn) 294
7.2.5 共享服务器进程(Shared Server Processes,Snnn) 294
7.3 共享服务器模式实务 294
7.4 共享服务器模式疑难解析 305
第8章 掌握两个管理问题——表空间和数据文件的管理 317
8.1 数据库存储结构 317
8.1.1 物理结构 317
8.1.2 逻辑结构 320
8.2 深刻理解表空间 327
8.2.1 大文件表空间 327
8.2.2 系统表空间 327
8.2.3 辅助表空间 327
8.2.4 回滚表空间(Undo Tablespace) 327
8.2.5 临时表空间 330
8.2.6 表空间中区的管理方式 331
8.2.7 表空间中段的管理方式 332
8.2.8 非标准块表空间 333
8.2.9 表空间的离线(Offline)与在线(Online) 333
8.2.10 只读表空间(Read-Only Tablespace) 333
8.3 深刻理解数据文件 334
8.3.1 数据文件的内容 334
8.3.2 数据文件的尺寸(Size) 334
8.3.3 离线数据文件 334
8.3.4 临时数据文件(Temporary Datafiles) 334
8.4 表空间管理实务与疑难解析 335
8.4.1 永久表空间管理 335
8.4.2 临时表空间管理实务与疑难解析 366
8.4.3 回滚表空间管理实务与疑难解析 373
8.5 数据文件管理实务与疑难解析 379
8.5.1 数据文件管理实务 379
8.5.2 数据文件管理疑难解析 388
第9章 进程管理 390
9.1 Oracle进程简介 390
9.2 用户进程 391
9.3 Oracle进程 391
9.3.1 服务器进程 391
9.3.2 后台进程 391
9.4 进程综合管理实务与疑难解析 395
9.5 会话管理实务与疑难解析 403
第10章 内存管理 408
10.1 Oracle内存结构简介 408
10.2 系统全局区(SGA) 409
10.2.1 SGA简介 410
10.2.2 SGA组成 411
10.3 程序全局区(PGA) 414
10.3.1 私有SQL区 414
10.3.2 SQL工作区 415
10.3.3 用户全局区 415
10.4 软件代码区 415
10.5 管理Oracle内存的方式 415
10.5.1 PGA自动管理 415
10.5.2 SGA自动管理 416
10.5.3 自动内存管理 416
10.6 内存管理实务与疑难解析 416
第11章 用户管理 439
11.1 用户验证 440
11.1.1 口令认证 440
11.1.2 外部认证 440
11.1.3 全局认证 441
11.2 Oracle的安全大门——权限(Privileges) 441
11.2.1 系统权限 441
11.2.2 对象权限 444
11.3 使权限管理变得更加容易——角色(Role) 445
11.4 限制用户的资源消耗——资源限制文件(Profile) 446
11.4.1 资源限制的级别 447
11.4.2 限制资源的参数 447
11.5 用户与权限管理实务与疑难解析 448
11.5.1 用户管理实务与疑难解析 448
11.5.2 权限管理实务与疑难解析 453
11.5.3 角色管理实务与疑难解析 457
11.5.4 资源限制文件管理实务与疑难解析 463
第4篇 移动数据库
第12章 数据导出 468
12.1 数据导出方法介绍 468
12.1.1 Oracle最新导出工具——Data Pump Export 468
12.1.2 Oracle原来的导出工具——Export 468
12.2 数据导出实务 471
12.3 数据导出疑难解析 489
第13章 数据导入 508
13.1 数据导入方法介绍 508
13.1.1 Oracle最新导入工具——Data Pump Import 508
13.1.2 Oracle以前的导入方法——Import 508
13.2 数据导入实务 510
13.3 数据导入疑难解析 530
第5篇 Oracle文件管理
第14章 重中之重——控制文件的管理 544
14.1 控制文件的概念 544
14.2 控制文件管理实务与疑难解析 545
第15章 成为数据库的最高统治者——口令文件(Password File)管理 555
15.1 超级用户权限(SYSDBA、SYSOPER)介绍 555
15.2 口令文件的基本概念 556
15.3 启用口令文件认证 557
15.4 口令文件管理实务与疑难解析 558
第16章 联机日志文件管理 571
16.1 联机日志文件的概念 571
16.1.1 联机日志文件的内容 571
16.1.2 联机日志文件的循环利用 572
16.2 联机日志文件管理实务与疑难解析 572
第17章 参数文件(PFILE/SPFILE)管理 584
17.1 参数文件的基本概念 584
17.2 初始化参数文件 585
17.3 服务器参数文件 585
17.4 初始化参数的修改 585
17.5 参数管理实务与疑难解析 586
第6篇 Oracle高级专题
第18章 全球应用——分布式数据库疑难攻略 594
18.1 分布式数据库系统的概念 594
18.1.1 同构分布式数据库系统 595
18.1.2 异构分布式数据库系统 595
18.1.3 数据库链接(Database Link) 595
18.2 分布式数据库管理实务与疑难解析 595
第19章 并不陌生的问题——裸设备 603
19.1 裸设备的概念 603
19.2 裸设备管理实务与疑难解析 604
第7篇 数据库备份/恢复
第20章 备份/恢复之基石——归档(Archivelog)管理 612
20.1 归档的基本概念 612
20.1.1 非归档模式 612
20.1.2 归档模式 613
20.1.3 归档路径 613
20.2 归档管理实务与疑难解析 614
第21章 必行之举——数据库备份 636
21.1 理解数据库备份 636
21.1.1 数据库失败的种类 637
21.1.2 备份和恢复的解决方案 637
21.1.3 备份和恢复的物理结构 638
21.1.4 备份的类型 638
21.1.5 执行用户管理的备份 638
21.2 恢复管理器(RMAN) 639
21.2.1 通道 640
21.2.2 备份集的维护 640
21.2.3 RMAN资料库 642
21.2.4 RMAN的使用 643
21.3 数据库备份实务与疑难解析 643
21.4 恢复目录管理实务与疑难解析 665
第22章 失而复得——数据库恢复 673
22.1 数据库恢复 673
22.1.1 实例恢复 673
22.1.2 介质恢复 674
22.1.3 用户错误(User Error)的恢复 675
22.2 数据库闪回(Flashback Database) 676
22.3 用户管理的恢复(User-managed Recovery) 676
22.4 联机日志文件丢失的恢复 677
22.5 控制文件损坏的恢复 689
22.6 数据文件损坏的恢复 700
22.7 表的恢复(用户错误的恢复) 711
第8篇 Oracle程序设计
第23章 数据库通用语言——SQL语句 742
23.1 结构化查询语言简介 742
23.2 SELECT语句 743
23.2.1 理解SELECT语句 743
23.2.2 SELECT语句使用实务与疑难解析 744
23.3 INSERT语句 754
23.3.1 理解INSERT语句 754
23.3.2 INSERT语句使用实务与疑难解析 755
23.4 UPDATE语句 761
23.4.1 理解UPDATE语句 761
23.4.2 UPDATE语句使用实务与疑难解析 761
23.5 DELETE语句 763
23.5.1 理解DELETE语句 763
23.5.2 DELETE语句的使用 763
23.6 SQL语句中,集合函数使用实务与疑难解析 766
第24章 模式对象(Schema Object)的管理 771
24.1 模式(Schema)的概念 771
24.2 模式对象管理 772
24.2.1 表(Table) 772
24.2.2 索引(Index) 790
24.2.3 外部表(External Table) 795
24.2.4 临时表(Temporary Table) 805
24.2.5 分区表(Partition Table) 809
24.2.6 聚簇(Cluster) 822
24.2.7 索引组织表(Index-Organized Table,IOT) 825
24.2.8 视图 831
24.2.9 同义词 836
24.2.10 序列 839
第25章 PL/SQL应用程序开发 844
25.1 PL/SQL简述 844
25.1.1 PL/SQL块结构 844
25.1.2 数据类型 845
25.1.3 运算符 845
25.1.4 PL/SQL语句控制结构 846
25.2 存储过程(Stored Procedure) 847
25.2.1 存储过程的基本原理 847
25.2.2 存储过程管理实务与疑难解析 847
25.3 函数(Function) 863
25.3.1 函数的基本原理 863
25.3.2 函数的管理实务与疑难解析 863
25.4 包 871
25.4.1 包的基本原理 871
25.4.2 包管理实务与疑难解析 871
25.5 触发器 878
25.5.1 触发器的基本原理 878
25.5.2 触发器管理实务与疑难解析 879
25.6 游标 899
25.6.1 游标的基本原理 899
25.6.2 游标管理实务与疑难解析 899
第9篇 内存探索
第26章 勿忘历史——Oracle内存管理的变迁 908
26.1 Oracle 内存变迁概述 908
26.2 Oracle 7 的内存管理 908
26.3 Oracle 8/8i的内存管理 909
26.4 Oracle 9i的内存管理 909
26.5 Oracle 10g的内存管理 909
26.6 Oracle 11g的内存管理 909
第27章 SGA之家——共享内存段 911
27.1 共享内存段的基本概念 911
27.2 共享内存段与内核参数 911
27.3 数据库启动与共享内存段 911
27.4 设置共享内存段 912
27.5 共享内存段的管理工具 913
27.5.1 Oracle小工具——sysresv 914
27.5.2 Oracle调试工具——oradebug 914
27.5.3 操作系统工具——ipcs(ipcrm) 915
27.6 查看内核参数对共享内存段的限制 916
27.7 共享内存段的空间使用情况 916
27.8 共享内存段与进程 917
27.9 删除共享内存段 917
第28章 内存管理效率的提升——HugePage 919
28.1 HugePage的原理 919
28.2 HugePage的配置 920
28.3 HugePage疑难解析 923
第29章 内存管理方式的巨变——内存文件系统 928
29.1 内存文件系统 928
29.2 第一阶段:传统模式(共享内存段) 929
29.3 第二阶段:新型模式(内存文件系统) 929
29.4 第三阶段:内存文件系统的设置 931
29.5 第四阶段:从“新型模式”切换到“传统模式” 931
第10篇 I/O探索
第30章 永恒的主题——I/O(同步I/O、异步I/O、直接I/O) 934
30.1 磁盘的物理结构 934
30.1.1 盘片(碟片,Platter) 934
30.1.2 磁头(Head) 934
30.1.3 磁道(Track) 934
30.1.4 扇区(Sector) 934
30.2 磁盘工作原理 935
30.2.1 寻道时间(Seek Time) 935
30.2.2 旋转延迟(Rotational Latency) 935
30.2.3 传输时间(Transfer Time) 935
30.2.4 访问时间(Access Time) 935
30.3 衡量磁盘性能的两个指标 935
30.4 I/O介绍 935
30.4.1 同步I/O 936
30.4.2 异步I/O 936
30.4.3 直接I/O 936
30.4.4 Oracle与I/O配置 936
30.4.5 异步I/O的使用 936
30.4.6 直接I/O的使用 938
30.5 随机I/O和顺序I/O 939
30.5.1 随机I/O的原理 939
30.5.2 顺序I/O的原理 940
30.6 I/O大比拼 940
30.6.1 随机I/O和顺序I/O的巨大反差 940
30.6.2 同步I/O和异步I/O的对比 940
30.6.3 直接I/O与内存的使用 941
第11篇 RAC管理
第31章 理论奠基——RAC简介 944
31.1 高可用性介绍 944
31.2 Oracle 集群 945
31.3 硬件架构 946
31.3.1 服务器介绍 946
31.3.2 共享存储介绍 946
31.3.3 网络介绍 952
31.4 软件架构 954
31.4.1 软件分层 954
31.4.2 Oracle Clusterware软件 955
31.4.3 Oracle RAC软件 962
第32章 RAC的意义——负载均衡和失败转移 963
32.1 负载均衡 963
32.1.1 负载均衡简介 963
32.1.2 客户端负载均衡 964
32.1.3 服务器端负载均衡 967
32.2 失败转移 967
32.2.1 失败转移简介 967
32.2.2 失败转移实战 967
第33章 存储的主打曲——自动存储管理(ASM) 973
33.1 ASM基本概念 973
33.1.1 ASM实例(ASM Instance) 973
33.1.2 ASM磁盘组(ASM Disk Group) 973
33.1.3 ASM文件(ASM File) 974
33.1.4 区(Extent) 974
33.1.5 镜像和失败组(Mirroring and Failure Group) 975
33.2 配置ASM实例 976
33.2.1 创建ASM实例 976
33.2.2 ASM的初始化参数 978
33.2.3 ASM实例的连接 979
33.2.4 ASM的启动 979
33.2.5 ASM的关闭 980
33.2.6 检查ASM实例的状态 981
33.3 磁盘组的管理 981
33.3.1 准备磁盘(以裸设备为例) 981
33.3.2 确保ASM能够搜索到磁盘 984
33.3.3 创建磁盘组 985
33.3.4 磁盘组的加载/卸载 987
33.3.5 在磁盘组上创建表空间 988
33.3.6 往磁盘组中添加磁盘 989
33.3.7 从磁盘组中删除磁盘 989
33.3.8 删除磁盘组 989
33.3.9 手工重平衡磁盘组中的文件 990
33.3.10 磁盘和磁盘组的信息 990
33.4 管理工具ASMCMD 991
33.5 动态卷管理器(ADVM)和集群文件系统(ACFS) 992
33.5.1 动态卷管理器(ADVM)的使用 993
33.5.2 集群文件系统(ACFS)的使用 996
33.6 ASM管理疑难解析 997
第34章 练兵场——RAC管理 1003
34.1 你必须清楚的一件情——命令运行环境 1003
34.2 集群管理工具 1003
34.3 集群的启动和关闭 1004
34.4 IP地址管理 1005
34.4.1 SCAN VIP的漂移 1005
34.4.2 检查SCAN的配置 1005
34.4.3 修改SCAN VIP和VIP 1005
34.4.4 私有IP地址的修改 1008
34.4.5 修改SCAN监听器的端口 1009
34.5 实例的管理 1010
34.5.1 实例的启动和关闭 1010
34.5.2 数据库的启动和关闭 1011
34.5.3 参数文件(PFILE、SPFILE)管理 1011
34.5.4 会话管理 1013
34.6 物理结构管理 1013
34.6.1 回滚表空间的管理 1013
34.6.2 联机重做日志的管理 1014
34.6.3 集群注册表(OCR)的管理 1015
34.6.4 Oracle本地注册表(OLR)的管理 1019
34.6.5 表决盘(Voting Disk)的管理 1020
34.6.6 集群注册表和表决盘管理实务 1022
34.7 节点管理 1029
34.7.1 节点失败那点事儿 1029
34.7.2 数据库管理模式 1030
34.7.3 删除节点 1031
34.7.4 增加节点 1042
· · · · · · (收起)
Oracle数据库精讲与疑难解析的书评 · · · · · · ( 全部 0 条 )
论坛 · · · · · ·
在这本书的论坛里发言在哪儿借这本书 · · · · · ·
谁读这本书? · · · · · ·
二手市场
· · · · · ·
- 在豆瓣转让 有5人想读,手里有一本闲着?
订阅关于Oracle数据库精讲与疑难解析的评论:
feed: rss 2.0
还没人写过短评呢
还没人写过短评呢