《Oracle 9i&10g编程艺术:数据库体系结构》PDF下载

  • 购买积分:20 如何计算积分?
  • 作  者:(美)Thomas Kyte编著;苏余国等译
  • 出 版 社:北京:人民邮电出版社
  • 出版年份:2006
  • ISBN:711515032X
  • 页数:737 页
图书介绍:本书是一本有关Oracle数据库的权威书籍。

第1章 开发成功的Oracle应用 1

1.1 我的方法 2

1.2 黑盒方法 4

1.3 开发数据库应用的正确(和不正确)方法 8

1.3.1 了解Oracle体系结构 8

1.3.2 理解并发控制 14

1.3.3 多版本 19

1.3.4 数据库独立性? 25

1.3.5 “怎么能让应用运行得更快?” 41

1.3.6 DBA与开发人员的关系 45

1.4 小结 46

第2章 体系结构概述 47

2.1 定义数据库和实例 48

2.2 SGA和后台进程 53

2.3.1 专用服务器 56

2.3 连接Oracle 56

2.3.2 共享服务器 57

2.3.3 TCP/IP连接的基本原理 58

2.4 小结 61

第3章 文件 63

3.1 参数文件 64

3.1.1 什么是参数? 65

3.1.2 遗留的init.ora参数文件 67

3.1.3 服务器参数文件 69

3.1.4 参数文件小结 75

3.2 跟踪文件 76

3.2.1 请求的跟踪文件 77

3.2.2 针对内部错误生成的跟踪文件 80

3.2.3 跟踪文件小结 83

3.3 警告文件 83

3.4 数据文件 86

3.4.1 简要回顾文件系统机制 86

3.4.2 Oracle数据库中的存储层次体系 87

3.4.3 字典管理和本地管理的表空间 91

3.5 临时文件 93

3.6 控制文件 95

3.7 重做日志文件 95

3.7.1 在线重做日志 96

3.7.2 归档重做日志 98

3.8 密码文件 100

3.9 修改跟踪文件 103

3.10 闪回日志文件 104

3.10.1 闪回数据库 104

3.10.2 闪回恢复区 105

3.11 DMP文件(EXP/IMP文件) 106

3.12 数据泵文件 107

3.13 平面文件 110

3.14 小结 111

4.1 进程全局区和用户全局区 113

第4章 内存结构 113

4.1.1 手动PGA内存管理 114

4.1.2 自动PGA内存管理 121

4.1.3 手动和自动内存管理的选择 131

4.1.4 PGA和UGA小结 132

4.2 系统全局区 133

4.2.1 固定SGA 137

4.2.2 重做缓冲区 137

4.2.3 块缓冲区缓存 138

4.2.4 共享池 145

4.2.5 大池 148

4.2.6 Java池 149

4.2.7 流池 150

4.2.8 自动SGA内存管理 150

4.3 小结 151

第5章 Oracle进程 153

5.1 服务器进程 153

5.1.1 专用服务器连接 154

5.1.2 共享服务器连接 156

5.1.3 连接与会话 157

5.1.4 专用服务器与共享服务器 163

5.1.5 专用/共享服务器小结 166

5.2 后台进程 167

5.2.1 中心后台进程 168

5.2.2 工具后台进程 175

5.3 从属进程 178

5.3.1 I/O从属进程 178

5.3.2 并行查询从属进程 179

5.4 小结 179

第6章 锁 181

6.1 什么是锁? 181

6.2 锁定问题 184

6.2.1 丢失更新 184

6.2.2 悲观锁定 185

6.2.3 乐观锁定 187

6.2.4 乐观锁定还是悲观锁定? 197

6.2.5 阻塞 198

6.2.6 死锁 201

6.2.7 锁升级 206

6.3 锁类型 206

6.3.1 DML锁 207

6.3.2 DDL锁 215

6.3.3 闩 218

6.3.4 手动锁定和用户定义锁 226

6.4 小结 227

第7章 并发与多版本 229

7.1 什么是并发控制? 229

7.2 事务隔离级别 230

7.2.1 READ UNCOMMITTED 232

7.2.2 READ COMMITTED 233

7.2.3 REPEATABLE READ 235

7.2.4 SERIALIZABLE 237

7.2.5 READ ONLY 239

7.3 多版本读一致性的含义 240

7.3.1 一种会失败的常用数据仓库技术 240

7.3.2 解释热表上超出期望的I/O 241

7.4 写一致性 244

7.4.1 一致读和当前读 244

7.4.2 查看重启动 247

7.4.3 为什么重启动对我们很重要? 250

7.5 小结 251

第8章 事务 253

8.1 事务控制语句 254

8.2 原子性 255

8.2.1 语句级原子性 255

8.2.2 过程级原子性 257

8.3.1 IMMEDIATE约束 260

8.3 完整性约束和事务 260

8.2.3 事务级原子性 260

8.3.2 DEFERRABLE约束和级联更新 261

8.4 不好的事务习惯 263

8.4.1 在循环中提交? 264

8.4.2 使用自动提交? 270

8.5 分布式事务 271

8.6 自治事务 273

8.6.1 自治事务如何工作? 273

8.6.2 何时使用自治事务? 276

8.7 小结 279

第9章 redo与undo 281

9.1 什么是redo? 281

9.2 什么是undo? 282

9.3 redo和undo如何协作? 285

9.4 提交和回滚处理 289

9.4.1 COMMIT做什么? 289

9.4.2 ROLLBACK做什么? 296

9.5 分析redo 297

9.5.1 测量redo 298

9.5.2 redo生成和BEFORE/AFTER触发器 300

9.5.3 我能关掉重做日志生成吗? 306

9.5.4 为什么不能分配一个新日志? 310

9.5.5 块清除 312

9.5.6 日志竞争 315

9.5.7 临时表和redo/undo 317

9.6 分析undo 321

9.6.1 什么操作会生成最多和最少的undo? 321

9.6.2 ORA-01555:snapshot too old错误 323

9.7 小结 334

第10章 数据库表 335

10.1 表类型 335

10.2.1 段 337

10.2 术语 337

10.2.2 段空间管理 339

10.2.3 高水位线 340

10.2.4 freelists 342

10.2.5 PCTFREE和PCTUSED 345

10.2.6 LOGGING和NOLOGGING 348

10.2.7 INITRANS和MAXTRANS 349

10.3 堆组织表 349

10.4 索引组织表 352

10.5 索引聚簇表 368

10.6 散列聚簇表 376

10.7 有序散列聚簇表 386

10.8 嵌套表 390

10.8.1 嵌套表语法 390

10.8.2 嵌套表存储 399

10.8.3 嵌套表小结 402

10.9 临时表 402

10.10 对象表 410

10.11 小结 418

第11章 索引 421

11.1 Oracle索引概述 422

11.2 B*树索引 423

11.2.1 索引键压缩 426

11.2.2 反向键索引 429

11.2.3 降序索引 435

11.2.4 什么情况下应该使用B*树索引? 437

11.2.5 B*树小结 448

11.3 位图索引 448

11.3.1 什么情况下应该使用位图索引? 449

11.3.2 位图联结索引 453

11.3.3 位图索引小结 455

11.4 基于函数的索引 456

11.4.1 重要的实现细节 456

11.4.2 一个简单的基于函数的索引例子 457

11.4.3 只对部分行建立索引 465

11.4.4 实现有选择的惟一性 467

11.4.5 关于CASE的警告 467

11.4.6 关于ORA-01743的警告 469

11.4.7 基于函数的索引小结 470

11.5 应用域索引 470

11.6 关于索引的常见问题和神话 472

11.6.1 视图能使用索引吗? 472

11.6.2 Null和索引能协作吗? 472

11.6.3 外键是否应该加索引? 475

11.6.4 为什么没有使用我的索引? 476

11.6.5 神话:索引中从不重用空间 483

11.6.6 神话:最有差别的元素应该在最前面 486

11.7 小结 490

第12章 数据类型 491

12.1 Oracle数据类型概述 491

12.2.1 NLS概述 494

12.2 字符和二进制串类型 494

12.2.2 字符串 497

12.3 二进制串:RAW类型 504

12.4 数值类型 506

12.4.1 NUMBER类型的语法和用法 509

12.4.2 BINARY_FLOAT/BINARY_DOUBLE类型的语法和用法 513

12.4.3 非固有数值类型 513

12.4.4 性能考虑 514

12.5 LONG类型 515

12.5.1 LONG和LONG RAW类型的限制 516

12.5.2 处理遗留的LONG类型 517

12.6 DATE、TIMESTAMP和INTERVAL类型 523

12.6.1 格式 523

12.6.2 DATE类型 525

12.6.3 TIMESTAMP类型 533

12.6.4 INTERVAL类型 541

12.7 LOB类型 544

12.7.1 内部LOB 545

12.7.2 BFILE 557

12.8 ROWID/UROWID类型 559

12.9 小结 560

第13章 分区 561

13.1 分区概述 561

13.1.1 提高可用性 562

13.1.2 减少管理负担 564

13.1.3 改善语句性能 569

13.2 表分区机制 571

13.2.1 区间分区 571

13.2.2 散列分区 574

13.2.3 列表分区 579

13.2.4 组合分区 581

13.2.5 行移动 583

13.2.6 表分区机制小结 585

13.3 索引分区 586

13.3.1 局部索引与全局索引 587

13.3.2 局部索引 587

13.3.3 全局索引 594

13.4 再论分区和性能 610

13.5 审计和段空间压缩 617

13.6 小结 618

第14章 并行执行 619

14.1 何时使用并行执行 620

14.2 并行查询 622

14.3 并行DML 628

14.4 并行DDL 631

14.4.1 并行DDL和使用外部表的数据加载 632

14.4.2 并行DDL和区段截断 634

14.5 并行恢复 643

14.6 过程并行化 643

14.6.1 并行管道函数 644

14.6.2 DIY并行化 648

14.7 小结 652

第15章 数据加载和卸载 655

15.1 SQL*Loader 655

15.1.1 用SQLLDR加载数据的FAQ 660

15.1.2 SQLLDR警告 686

15.1.3 SQLLDR小结 686

15.2 外部表 687

15.2.1 建立外部表 688

15.2.2 处理错误 693

15.2.3 使用外部表加载不同的文件 697

15.2.4 多用户问题 697

15.2.5 外部表小结 698

15.3 平面文件卸载 698

15.4 数据泵卸载 708

15.5 小结 710

索引 711