精通Oracle SQL

精通Oracle SQL

(美) 莫顿 (Morton,K.) , 等著

出版社:人民邮电出版社

年代:2014

定价:99.0

书籍简介:

本书作者以精炼、风趣的语言揭开了Oracle SQL高级编程的神秘面纱。所涵盖的内容涉及SQL核心、SQL执行、分析函数、联结、测试与质量保证等,并提供大量实用性建议,且总结出方方面面的“技巧”帮助读者在阅读过程中快速消化所看内容。

书籍目录:

目 录

第1章 SQL核心 1

1.1 SQL语言 1

1.2 数据库的接口 2

1.3 SQL*Plus回顾 3

1.3.1 连接到数据库 3

1.3.2 配置SQL*Plus环境 4

1.3.3 执行命令 6

1.4 5个核心的SQL语句 8

1.5 SELECT语句 8

1.5.1 FROM子句 10

1.5.2 WHERE子句 11

1.5.3 GROUP BY子句 11

1.5.4 HAVING子句 12

1.5.5 SELECT列表 13

1.5.6 ORDER BY子句 13

1.6 INSERT语句 14

1.6.1 单表插入 14

1.6.2 多表插入 15

1.7 UPDATE语句 17

1.8 DELETE语句 20

1.9 MERGE语句 22

1.10 小结 24

第2章 SQL执行 25

2.1 Oracle架构基础 25

2.2 SGA共享池 26

2.3 库高速缓存 27

2.4 完全相同的语句 28

2.5 SGA缓冲区缓存 31

2.6 查询转换 34

2.6.1 查询块 35

2.6.2 视图合并 37

2.6.3 子查询解嵌套 41

2.6.4 联结消除 43

2.6.5 排序消除 45

2.6.6 谓词推进 46

2.6.7 使用物化视图进行查询重写 48

2.7 确定执行计划 50

2.8 执行计划并取得数据行 54

2.9 SQL执行——总览 56

2.10 小结 57

第3章 访问和联结方法 58

3.1 全扫描访问方法 58

3.1.1 如何选择全扫描操作 59

3.1.2 全扫描与舍弃 62

3.1.3 全扫描与多块读取 63

3.1.4 全扫描与高水位线 63

3.2 索引扫描访问方法 68

3.2.1 索引结构 69

3.2.2 索引扫描类型 71

3.2.3 索引唯一扫描 75

3.2.4 索引范围扫描 76

3.2.5 索引全扫描 77

3.2.6 索引跳跃扫描 80

3.2.7 索引快速全扫描 81

3.3 联结方法 82

3.3.1 嵌套循环联结 83

3.3.2 排序—合并联结 85

3.3.3 散列联结 86

3.3.4 笛卡儿联结 89

3.3.5 外联结 90

3.4 小结 95

第4章 SQL是关于集合的 96

4.1 以面向集合的思维方式来思考 96

4.1.1 从面向过程转变为基于集合的思维方式 97

4.1.2 面向过程与基于集合的思维方式:例子 100

4.2 集合运算 102

4.2.1 UNION和UNION ALL 103

4.2.2 MINUS 106

4.2.3 INTERSECT 107

4.3 集合与空值 108

4.3.1 空值与非直观结果 108

4.3.2 空值与集合运算 111

4.3.3 空值与GROUP BY和ORDER BY 112

4.3.4 空值与聚合函数 114

4.4 小结 114

第5章 提出问题 115

5.1 问出好的问题 115

5.2 提问的目的 116

5.3 问题的种类 116

5.4 问题的问题 118

5.5 数据的问题 120

5.6 建立逻辑表达式 125

5.7 小结 130

第6章 SQL执行计划 131

6.1 解释计划 131

6.1.1 使用解释计划 131

6.1.2 PLAN_TABLE 133

6.1.3 分解计划 135

6.1.4 导致解释计划未达目的的原因 136

6.1.5 阅读计划 139

6.1.6 访问和筛选谓语 140

6.1.7 使计划便于阅读 141

6.2 执行计划 142

6.2.1 查看最近生成的SQL语句 142

6.2.2 查看相关执行计划 142

6.2.3 收集执行计划统计信息 144

6.2.4 标识SQL语句以便以后取回计划 146

6.2.5 深入理解DBMS_XPLAN 149

6.2.6 使用SQL监控报告 154

6.2.7 使用计划信息解决问题 157

6.3 小结 166

第7章 高级分组 167

7.1 基本的GROUP BY用法 167

7.2 HAVING子句 170

7.3 GROUP BY的“新”功能 172

7.4 GROUP BY的CUBE扩展 172

7.5 CUBE的实际应用 178

7.6 用GROUPING()函数排除空值 184

7.7 用GROUPING()扩展报告 185

7.8 用GROUPING_ID()扩展报告 186

7.9 GROUPING SETS与ROLLUP() 190

7.10 GROUP BY局限性 192

7.11 小结 195

第8章 分析函数 196

8.1 概览 196

8.2 示例数据 197

8.3 分析函数剖析 197

8.4 函数列表 198

8.5 聚合函数 199

8.5.1 跨越整个分区的聚合函数 200

8.5.2 细粒度窗口声明 201

8.5.3 默认窗口声明 201

8.6 lead和lag 201

8.6.1 语法和排序 202

8.6.2 例1:从前一行中返回一个值 202

8.6.3 理解数据行的位移 203

8.6.4 例2:从下一行中返回一个值 203

8.7 first_value和last_value 204

8.7.1 例子:使用first_value计算最大值 205

8.7.2 例子:使用last_value计算最小值 206

8.8 其他分析函数 206

8.8.1 nth_value 206

8.8.2 rank 208

8.8.3 dense_rank 209

8.8.4 row_number 210

8.8.5 ratio_to_report 211

8.8.6 percent_rank 212

8.8.7 percentile_cont 213

8.8.8 percentile_disc 215

8.8.9 NTILE 216

8.8.10 stddev 217

8.8.11 listagg 218

8.9 性能调优 219

8.9.1 执行计划 220

8.9.2 谓词 220

8.9.3 索引 221

8.10 高级话题 222

8.10.1 动态SQL 222

8.10.2 嵌套分析函数 224

8.10.3 并行 224

8.10.4 PGA大小 225

8.11 组织行为 225

8.12 小结 226

第9章 MODEL子句 227

9.1 电子表格 228

9.2 使用MODEL子句实现跨行引用 228

9.2.1 示例数据 228

9.2.2 剖析MODEL子句 229

9.2.3 规则 230

9.3 位置和符号引用 231

9.3.1 位置标记 231

9.3.2 符号标记 232

9.3.3 FOR循环 233

9.4 返回更新后的行 234

9.5 求解顺序 235

9.5.1 行求解顺序 235

9.5.2 规则求解顺序 237

9.6 聚合 239

9.7 迭代 240

9.7.1 示例 240

9.7.2 PRESENTV与空值 241

9.8 查找表 242

9.9 空值 244

9.10 使用MODEL子句进行性能调优 245

9.10.1 执行计划 245

9.10.2 谓词推进 248

9.10.3 物化视图 250

9.10.4 并行 251

9.10.5 MODEL子句执行中的分区 252

9.10.6 索引 253

9.11 子查询因子化 254

9.12 小结 255

第10章 子查询因子化 256

10.1 标准用法 256

10.2 用WITH定义PL/SQL函数 259

10.3 SQL优化 261

10.3.1 测试执行计划 261

10.3.2 测试查询改变的影响 265

10.3.3 寻找其他优化机会 268

10.3.4 将子查询因子化应用到PL/SQL中 272

10.4 递归子查询 275

10.4.1 CONNECT BY示例 275

10.4.2 RSF示例 277

10.4.3 RSF的限制条件 278

10.4.4 与CONNECT BY的不同点 278

10.5 复制CONNECT BY的功能 279

10.5.1 LEVEL伪列 280

10.5.2 SYS_CONNECT_BY_PATH函数 281

10.5.3 CONNECT_BY_ROOT运算符 283

10.5.4 CONNECT_BY_ISCYCLE伪列和NOCYCLE参数 285

10.5.5 CONNECT_BY_ISLEAF伪列 288

10.6 小结 292

第11章 半联结和反联结 294

11.1 半联结 294

11.2 半联结执行计划 302

11.3 控制半联结执行计划 307

11.3.1 使用提示控制半联结执行计划 307

11.3.2 在实例级控制半联结执行计划 309

11.4 半联结限制条件 311

11.5 半联结必要条件 313

11.6 反联结 314

11.7 反联结执行计划 318

11.8 控制反联结执行计划 327

11.8.1 使用提示控制反联结执行计划 327

11.8.2 在实例级控制反联结执行计划 328

11.9 反联结限制条件 331

11.10 反联结必要条件 334

11.11 小结 334

第12章 索引 335

12.1 理解索引 336

12.1.1 什么时候使用索引 336

12.1.2 列的选择 338

12.1.3 空值问题 339

12.2 索引结构类型 340

12.2.1 B-树索引 340

12.2.2 位图索引 341

12.2.3 索引组织表 342

12.3 分区索引 344

12.3.1 局部索引 344

12.3.2 全局索引 346

12.3.3 散列分区与范围分区 347

12.4 与应用特点相匹配的解决方案 350

12.4.1 压缩索引 350

12.4.2 基于函数的索引 352

12.4.3 反转键索引 354

12.4.4 降序索引 355

12.5 管理问题的解决方案 356

12.5.1 不可见索引 356

12.5.2 虚拟索引 358

12.5.3 位图联结索引 358

12.6 小结 360

第13章 SELECT以外的内容 361

13.1 INSERT 361

13.1.1 直接路径插入 361

13.1.2 多表插入 363

13.1.3 条件插入 365

13.1.4 DML错误日志 365

13.2 UPDATE 371

13.2.1 CTAS与UPDATE的差别 371

13.2.2 INSERT APPEND与UPDATE的差别 374

13.3 DELETE 377

13.4 MERGE 380

13.4.1 语法和用法 380

13.4.2 性能比较 384

13.5 小结 385

第14章 事务处理 387

14.1 什么是事务 387

14.2 事务的ACID属性 388

14.3 事务隔离级别 389

14.4 多版本读一致性 391

14.5 事务控制语句 392

14.5.1 Commit(提交) 392

14.5.2 Savepoint(保存点) 392

14.5.3 Rollback(回滚) 392

14.5.4 Set Transaction(设置事务) 392

14.5.5 Set Constraints(设置约束) 393

14.6 将运算分组为事务 393

14.7 订单录入模式 394

14.8 活动事务 400

14.9 使用保存点 401

14.10 序列化事务 404

14.11 隔离事务 407

14.12 自治事务 410

14.13 小结 414

第15章 测试与质量保证 415

15.1 测试用例 416

15.2 测试方法 417

15.2.1 单元测试 418

15.2.2 回归测试 421

15.2.3 模式修改 422

15.2.4 重复单元测试 425

15.3 执行计划比较 426

15.4 性能测量 431

15.4.1 在代码中加入性能测量 432

15.4.2 性能测试 436

15.5 破坏性测试 437

15.6 使用性能测量进行系统检修 439

15.7 小结 441

第16章 计划稳定性 443

16.1 计划不稳定性:理解这个问题 443

16.1.1 统计信息的变化 444

16.1.2 运行环境的改变 446

16.1.3 SQL语句的改变 448

16.1.4 绑定变量窥视 448

16.1.5 自适应游标共享 451

16.2 统计信息反馈 455

16.3 识别执行计划的不稳定性 459

16.3.1 抓取当前运行查询的数据 460

16.3.2 查看语句的性能历史 461

16.3.3 按照执行计划聚合统计信息 462

16.3.4 寻找执行计划的统计方差 463

16.3.5 在一个时间点附近检查偏差 464

16.4 小结 465

第17章 计划控制 466

17.1 执行计划控制:解决问题 466

17.1.1 调整查询结构 467

17.1.2 适当使用常量 467

17.1.3 给优化器一些提示 467

17.2 执行计划控制:不能直接访问代码 475

17.2.1 选项1:改变统计信息 475

17.2.2 选项2:改变数据库参数 477

17.2.3 选项3:增加或移除访问路径 478

17.2.4 选项4:应用基于提示的执行计划控制机制 478

17.2.5 大纲 479

17.2.6 SQL概要文件 482

17.2.7 SQL执行计划基线 498

17.2.8 SQL补丁 507

17.2.9 基于提示的计划控制机理小结 509

17.3 小结 509

第18章 其他SQL结构 510

18.1 条件逻辑结构 510

18.1.1 DECODE 510

18.1.2 CASE 511

18.1.3 NVL、NVL2和COALESCE 515

18.1.4 NULLIF 517

18.2 PIVOT/UNPIVOT查询 518

18.2.1 PIVOT 518

18.2.2 UNPIVOT 523

18.3 生成测试数据的SQL 526

18.3.1 想要得到什么样的数据 526

18.3.2 CONNECT BY 527

18.3.3 MODEL子句 529

18.3.4 递归WITH子句 529

18.3.5 数据生成小结 530

18.4 小结 530

内容摘要:

《精通Oracle SQL(第2版)》由Oracle 数据库领域顶尖技术组织OakTable成员倾力打造,第1版热卖,读者好评如潮。书中主要介绍了如何掌握在Oracle数据库中实现的强大SQL特性,所涵盖的内容涉及SQL核心、SQL执行、分析函数、联结、测试与质量保证等,并提供了大量实用的建议,总结出方方面面的“技巧”,帮助读者快速消化重要知识点。新版将数据库版本升级到12c,对旧版进行了大幅修订,并阐述了很多新特性。作为Oracle SQL经典著作,《精通Oracle SQL(第2版)》为SQL开发人员指明了前行方向,赋予了他们不断开拓的动力。《精通Oracle SQL(第2版)》语言精炼、风趣,所涵盖的内容涉及SQL核心、SQL执行、分析函数、联结、测试与质量保证等,并提供大量实用性建议,且总结出方方面面的“技巧”,帮助读者在阅读过程中快速消化所看内容。新版针对Oracle 12c进行了大幅修订,以反映技术的最新发展动态。  《精通Oracle SQL(第2版)》旨在为Oracle数据库开发人员、DBA和架构师提供参考。【作者简介】 Karen Morton,研究人员、教育家及顾问,Fidelity信息服务公司资深数据库管理员和性能调优专家。她从20世纪90年代初就开始使用Oracle,从事Oracle教学工作也已经超过10年的时间。她是Oracle ACE和OakTable的成员,经常在技术会议上演讲。她的著作还包括Expert Oracle Practices和Beginning Oracle SQL。Kerry Osborne,Enkitec公司(提供Oracle咨询服务)联合创始人。从1982年开始使用Oracle(第2版)。他当过开发人员,也做过DBA,目前是Oracle ACE总监和OakTable成员。最近几年,他专注于研究Oracle内部原理以及解决性能问题。Robyn Sands,思科公司软件工程师,为思科客户设计开发嵌入式Oracle数据库产品。从1996年开始使用Oracle,在应用开发、大型系统实现以及性能评估方面具有丰富的经验。她是OakTable的成员,同时是Expert Oracle Practices 一书的合著者。Riyaj Shamsudeen,OraInternals(专注于性能/数据恢复/电子商务的咨询公司)董事长、首席数据库管理员。有近20年使用Oracle技术产品以及Oracle数据库管理员/Oracle数据库应用管理员的经验,是真正应用集群、性能调优以及数据库内部属性方面的专家。同时是一位演讲家及Oracle ACE。Jared Still,从1994年就开始使用Oracle。他认为对于SQL的学习是永无止境的,相信只有精通SQL语言才能写出查询Oracle数据库的高效语句。他参与本书的编写就是为了帮助别人实现这一目标。

书籍规格:

书籍详细信息
书名精通Oracle SQL站内查询相似图书
丛书名图灵程序设计丛书
9787115351661
如需购买下载《精通Oracle SQL》pdf扫描版电子书或查询更多相关信息,请直接复制isbn,搜索即可全网搜索该ISBN
出版地北京出版单位人民邮电出版社
版次1版印次1
定价(元)99.0语种简体中文
尺寸24 × 19装帧平装
页数 250 印数 4000

书籍信息归属:

精通Oracle SQL是人民邮电出版社于2014.6出版的中图分类号为 TP311.138 的主题关于 关系数据库系统 的书籍。