
作者:(美)罗森布拉姆(MichaelRos
页数:235
出版社:清华大学出版社
出版日期:2015
ISBN:9787302419563
电子书格式:pdf/epub/txt
内容简介
经证实的PL/SQL优化解决方案 在《Oracle PL/SQL性能调优诀窍与方法》这本书中,作为Oracle ACE的两位作者给出了一种方便的能够从PL/SQL获取最佳结果的方法,他们有着数十年为政府、企业和教育机构创建复杂生产系统的经验。本书首先介绍了精确定位性能问题的方法,并提供了可度量和验证的测试案例。在深入探讨SQL和PL/SQL的结合使用方法之后,又深入挖掘了适用于Oracle数据库的性能调优工具。本书通篇包含真实的示例和最佳实践。 主要内容 按照需求驱动的9步过程来识别和定位Web应用中的性能问题 使用性能相关的数据库工具,包括数据字典视图、日志、追踪、PL/SQL Hierarchical Profiler(PL/SQL层次式分析器)、PL/Scope和RUNSTATS 使用调用堆栈API、错误堆栈API和计时标记插装代码,以便定位性能问题 内嵌于SQL中的PL/SQL和管理用户定义的函数 使用一种基于集合的方法把SQL嵌入PL/SQL中以便处理大量数据 正确编写和部署DML触发器以避免性能问题 用高级数据类型进行工作,包括LOB和XML 使用缓存技术避免冗余操作 有效地利用动态SQL来减少所需的代码量和流水线系统管理 管理版本控制并确保性能修复得到成功部署。
作者简介
Michael Rosenblum是Dulcian,Inc.的一位软件架构师/高级DBA,负责系统调优和设计应用程序体系架构。Michael通过编写复杂的PL/SQL例程和研究新特性来为Dulcian的开发者提供支持。他是PL/SQL for Dummies(Wiley Press, 2006)一书的合著者,是Expert PL/SQL Practices (Apress, 2011)一书的贡献作者,也是大量与数据库相关的期刊文章和会议论文的作者。Michael是一位Oracle ACE,是众多Oracle用户组会议的活跃主持人,包括Oracle OpenWorld、ODTUG、IOUG Collaborate、RMOUG、NYOUG等,并获得了ODTUG
Kaleidoscope的2009年度最佳演讲人奖。他的祖国是乌克兰,他以优等生的身份毕业于基辅国家经济大学,获得信息系统专业的科学硕士学位。
Paul
Dorsey博士是Dulcian,Inc.的创始人和总裁,这是一家Oracle咨询公司,专门从事业务规则和基于Web的应用程序开发。他是Dulcian,Inc.的Business Rules Information Manager (BRIM)产品工具的总架构师,还是Oracle出版社出版的7本书的合著者,这些书涵盖了Designer、数据库设计、Developer和JDeveloper等主题,已被翻译为9种语言,他还是Wiley出版社出版的PL/SQL for Dummies图书的合著者。Paul是一位Oracle ACE,并且是第一个进入IOUG SELECT名人堂的人。他是NYOUG的名誉主席。Paul于2003年被ODTUG授予年度志愿者称号,2001年被IOUG授予年度志愿者称号,是最早被Oracle授予Oracle 9i认证大师称号的6泰斗之一。Paul提交的用于为The
Preeclampsia Foundation收集数据的Survey Generator赢得了2007年度Oracle Fusion Middleware Developer
Challenge奖,Oracle选择他作为2007年度的PL/SQL Developer。
本书特色
经证实的pl/sql优化解决方案
在《oracle pl/sql性能调优诀窍与方法》这本书中,作为oracle ace的两位作者给出了一种方便的能够从pl/sql获取最佳结果的方法,他们有着数十年为政府、企业和教育机构创建复杂生产系统的经验。本书首先介绍了精确定位性能问题的方法,并提供了可度量和验证的测试案例。在深入探讨sql和pl/sql的结合使用方法之后,又深入挖掘了适用于oracle数据库的性能调优工具。本书通篇包含真实的示例和最佳实践。
主要内容
●
按照需求驱动的9步过程来识别和定位web应用中的性能问题
●
使用性能相关的数据库工具,包括数据字典视图、日志、追踪、pl/sql
hierarchical profiler(pl/sql层次式分析器)、pl/scope和runstats
●
使用调用堆栈api、错误堆栈api和计时标记插装代码,以便定位性能问题
●
内嵌于sql中的pl/sql和管理用户定义的函数
●
使用一种基于集合的方法把sql嵌入pl/sql中以便处理大量数据
●
正确编写和部署dml触发器以避免性能问题
●
用高级数据类型进行工作,包括lob和xml
●
使用缓存技术避免冗余操作
●
有效地利用动态sql来减少所需的代码量和流水线系统管理
●
管理版本控制并确保性能修复得到成功部署
目录
目 录 第ⅰ部分 pl/sql性能调优的核心理念和要素第1章 pl/sql在当前开发中的角色 31.1 典型的web应用程序处理流程 31.2 web应用程序的性能问题区域 41.2.1 步骤1:客户机的性能问题 41.2.2 步骤2:客户机到应用服务器的传输问题 51.2.3 步骤3:应用服务器的性能问题 51.2.4 步骤4:应用服务器到数据库的传输问题 51.2.5 步骤5:数据库的性能问题 51.2.6 步骤6:数据库到应用服务器的传输问题 61.2.7 步骤7:应用服务器处理性能问题 61.2.8 步骤8:应用服务器到客户机的传输问题 61.2.9 步骤9:客户机的性能问题 61.3 发现使得web应用程序性能变慢的原因 61.3.1 使用计时器来收集有关性能的数据 71.3.2 性能测量 81.4 解决web应用程序的性能问题 91.4.1 解决客户机的性能问题(步骤1和9) 91.4.2 分清客户机和应用服务器之间的性能问题(步骤2) 91.4.3 解决应用服务器中的性能问题(步骤3和7) 101.4.4 解决客户机中的性能问题(步骤9) 101.4.5 心得 101.5 总结 10第2章 dba/开发者的界线:工具和特性 132.1 数据字典视图 142.2 oracle日志记录和跟踪 162.2.1 日志记录的基础知识 162.2.2 跟踪的基础知识 172.2.3 日志记录/跟踪示例 182.3 pl/sql层次式分析器 202.4 runstats 232.5 pl/sql环境设置 242.5.1 plsql_optimize_level 252.5.2 plsql_code_type 272.5.3 plsql_warnings 292.5.4 plsql_ccflags 312.6 pl/scope 312.7 总结 33第3章 pl/sql中的代码插桩 353.1 问题真的出在数据库中吗 363.2 应用程序日志 373.2.1 内置代码导航api 373.2.2 用户驱动的日志 393.3 代码插桩的最佳实践 433.3.1 设置过程标记 443.3.2 设置错误标记 463.4 总结 47第ⅱ部分 链接sql和pl/sql第4章 扩展sql的范围 514.1 跳出sql模式 524.1.1 切换至pl/sql,使生活变得更简单 524.1.2 使用pl /sql填补功能空白 554.2 调用sql内置函数 594.2.1 单表问题 604.2.2 多表问题 634.3 和pl/sql相关的统计及其对执行计划的影响 644.3.1 pl /sql函数的硬件成本 644.3.2 pl/sql函数的基数 704.3.3 pl/sql函数的选择率 744.4 只有oracle database 12c才有的特性 774.4.1 pragma udf子句 774.4.2 在with子句中添加函数 784.5 总结 79第5章 用集合的概念来思考 815.1 游标 825.2 从sql到pl/sql加载集合 835.2.1 oracle database 12c:隐式分页与持续获取 885.2.2 用pl/sql合并集合 905.3 forall语句 945.3.1 保持语法最新:稀疏集合 965.3.2 直接插入 985.3.3 forall和表触发器 995.4 总结 101第6章 使用触发器 1036.1 dml触发器 1046.1.1 数据保护:约束与触发器 1046.1.2 默认值 1076.1.3 非规范化的代价 1106.2 instead of触发器 1126.2.1 基本的dml操作 1126.2.2 逻辑主键的危害 1156.2.3 处理update语句 1176.3 总结 120第ⅲ部分 调优人员的工具包第7章 不仅限于标量数据类型 1257.1 lob的管理 1267.1.1 访问lob 1267.1.2 存储机制 1277.1.3 i/o调优注意事项 1297.1.4 仅securefile才有的特性 1357.2 管理xml 1397.2.1 存储xml 1397.2.2 操作xml 1447.3 总结 148第8章 保持使用缓存 1518.1 内置缓存技术 1518.1.1 确定性函数 1528.1.2 标量子查询缓存 1568.1.3 pl/sql函数结果缓存 1588.2 手动缓存技术 1658.2.1 pl/sql集合 1668.2.2 oracle上下文 1688.3 总结 169第9章 射击移动目标 1719.1 扩展基础知识 1729.1.1 clob输入 1729.1.2 光标转换 1739.1.3 pl/sql函数结果缓存的集成 1739.1.4 支持复杂的数据类型 1759.2 深度挖掘 1799.2.1 有关搜索的更多内容 1799.2.2 列表内陷阱 1829.3 应对dynamic sql误解带来的挑战 1839.3.1 偏见#1:dynamic sql会引起安全风险 1849.3.2 偏见#2:dynamic sql总是比正规的sql慢 1849.3.3 偏见#3:dynamic sql总是引起解析 1859.3.4 偏见#4:ddl语句只能服务于dba 1879.4 总结 188第ⅳ部分 日常生活中的pl/sql第10章 来自战壕的传奇 19110.1 第三方的打包代码 19110.2 无状态问题 19410.3 未知的撤消 19710.4 递归的诅咒 20010.4.1 递归和光标 20010.4.2 递归和变量 20310.5 总结 203第11章 真实系统中的代码管理 20511.1 代码管理的问题 20611.1.1 dba的lite版 20711.1.2 国产版本控制 20911.2 基于版本的重定义和性能调优 21311.2.1 理解edition-based redefinition 21311.2.2 在oracle database 12c中对ebr所做的重要修改 21411.3 系统环境的差异以及与性能相关的代码管理 21711.4 总结 218第12章 额外的秘诀、技巧和理念 22112.1 回到基础 22112.1.1 varchar2内存的分配 22212.1.2 当前日期的成本 22312.1.3 二进制数据类型 22512.2 文本操作 22612.2.1 检查文本字符串的有效字符 22612.2.2 词的相似度 22812.2.3 varchar2和视图 230 12.3 增加处理的复杂性 23212.3.1 nocache优化 23212.3.2 accessible by子句 23412.3.3 关于流水线函数的更多知识 23512.4 总结 236
下载地址
立即下载(解压密码:www.teccses.org)
Article Title:《Oracle PL/SQL性能调优诀窍与方法》
Article link:
https://www.teccses.org/585547.html