Oracle 数据库优化实战心得总结


1.优化应用程序和业务逻辑,这个是最重要的。

2.数据库设计阶段范式和反范式的灵活应用。一般情况下,对于频繁访问但是不频繁修改的数据,内部设计应当物理不规范化;对于频繁修改但并不频繁访问的数据,内部设计应当物理规范化。

3.充分利用内存,优化sga、pga等(11g已经实现了sga+pga自动化,但有的时候仍然需要手动进行调整),适当的将小表keep到cache中。

4.优化sql语句
1)减少对数据库的查询次数,即减少对系统资源的请求,使用快照和显形图等分布式数据库对象可以减少对数据库的查询次数。
2)尽量使用相同的或非常类似的SQL语句进行查询,这样不仅充分利用SQL共享池中的已经分析的语法树,要查询的数据在SGA中命中的可能性也会大大增加。
3)限制动态SQL的使用,虽然动态SQL很好用,但是即使在SQL共享池中有一个完全相同的查询值,动态SQL也会重新进行语法分析。
4)避免不带任何条件的SQL语句的执行。没有任何条件的SQL语句在执行时,通常要进行FTS,数据库先定位一个数据块,然后按顺序依次查找其它数据,对于大型表这将 是一个漫长的过程。
5)如果对有些表中的数据有约束,最好在建表的SQL语句用描述完整性来实现,而不是用SQL程序中实现。
6)可以通过取消自动提交模式,将SQL语句汇集一组执行后集中提交,程序还可以通过显式地用COMMIT和ROLLBACL进行提交和回滚该事务。
7)检索大量数据时费时很长,设置行预取数则能改善系统的工作表现,设置一个最大值,当SQL语句返回行超过该值,数值库暂时停止执行,除非用户发出新的指令,开始组织并显示数据,而不是让用户继续等待。

5.优化io,将不同的数据文件、控制文件、日志文件放在不同的磁盘,表和索引放在不同的表空间,设置合适的block大小,设置异步io等。

6.适当建立只读表空间,减少数据块头的更新和数据库故障的发生。

7.表设计优化
1)分区
2)压缩
3)建立合适的索引
4)设置合适的pctfree,减少行连接和行迁移
5)设置合适的storage,控制表碎片
6)其他等

8.充分利用系统cpu资源,使用Parallel Query Option(PQO,并行查询选择)方式进行数据查询,使用PQO方式不仅可以在多个CPU间分配SQL语句的请求处理,当所查询的数据处于不同的磁盘时,一个个独立的进程可以同时进行数据读取。

9.优化数据库连接
1)使用直接的OLE DB数据库连接方式。
通过ADO可以使用两种方式连接数据库,一种是传统的ODBC方式,一种是OLE DB方式。ADO是建立在OLE DB技术上的,为了支持ODBC,必须建立相应的OLE DB到ODBC的调用转换,而使用直接的OLE DB方式则不需转换,从而提高处理速度。
2)使用Connection Pool机制
在数据库处理中,资源花销最大的是建立数据库连接,而且用户还会有一个较长的连接等待时间。解决的办法就是复用现有的Connection,也就是使用Connection Pool对象机制。
Connection Pool的原理是:IIS+ASP体系中维持了一个连接缓冲池,这样,当下一个用户访问时,直接在连接缓冲池中取得一个数据库连接,而不需重新连接数据库,因此可以大大地提高系统的响应速度。

10.充分利用数据的后台处理方案减少网络流量
1)合理创建临时表或视图
所谓创建临时表或视图,就是根据需要在数据库基础上创建新表或视图,对于多表关联后再查询信息的可建新表,对于单表查询的可创建视图,这样可充分利用数据库的容量大、可扩充性强等特点,所有条件的判断、数值计算统计均可在数据库服务器后台统一处理后追加到临时表中,形成数据结果的过程可用数据库的过程或函数来实现。
2)数据库打包技术的充分利用
利用数据库描述语言编写数据库的过程或函数,然后把过程或函数打成包在数据库后台统一运行包即可。
3)数据复制、快照、视图,远程过程调用技术的运用
数据复制,即将数据一次复制到本地,这样以后的查询就使用本地数据,但是只适合那些变化不大的数据。使用快照也可以在分布式数据库之间动态复制数据,定义快照的自动刷新时间或手工刷新,以保证数据的引用参照完整性。调用远程过程也会大大减少因频繁的SQL语句调用而带来的网络拥挤。

11.实施系统资源管理分配计划
ORACLE提供了Database Resource Manager(DRM,数据库资源管理器)来控制用户的资源分配,DBA可以用它分配用户类和作业类的系统资源百分比。在一个OLDP系统中,可给联机用户分配75%的CPU资源,剩下的25%留给批用户。另外,还可以进行CPU的多级分配。除了进行CPU资源分配外,DRM还可以对资源用户组执行并行操作的限制。



相关阅读:
yii权限控制的方法(三种方法)
JavaScript作用域链示例分享
win10 10074怎么开启暗黑主题模式?
非常经典的PHP文件上传类分享
android使用PopupWindow实现页面点击顶部弹出下拉菜单
JSP bean获取各种参数
Android五大布局与实际应用详解
Win8系统如何查看mac地址?Win8系统查看mac地址的两种方法
Windows出现BOOT\BCD错误的解决办法
js动态添加的DIV中的onclick事件简单实例
Asp.Net URL重写的具体实现
C#中Decimal类型截取保留N位小数并且不进行四舍五入操作
javascript实现数字+字母验证码的简单实例
win10系统时间不对怎么办?win10系统时间不准确问题的解决方法
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 彼时、之年 初中初二作文450字:海上生明月 小学五年级作文450字:在那个早晨 小心眼的你 2016迎国庆活动方案 我想要的其实很简单 小学语文教案-迷人的张家界 初一新生军训心得1200字 岁月,暴走的青春 山东寿光培训之后想创业 初中初一作文650字:聪明的蚂蚁 我的购物经验作文400字 消防工作应贯彻 孟加拉国的风俗礼仪 感恩·自然的精灵作文 演讲朗诵比赛活动方案 我爱唠叨的妈妈作文 金融危机下的服装行业定价决策简析 高中高三作文2800字:找出最好的材料,找到最好的例子——《家园,在我身后》点评 二年级开学趣事的作文:开学争取进步 小学五年级班级口号 带上信仰去旅行 雨的作文素材 梦萦千古作文800字 小学四年级语文学科质量调研检测分析报告 世界无烟日口号|世界无烟日口号作文素材 《周末大逃亡》读后感 父亲为什么选择了终身从教 入党积极分子思想汇报2013年9月:本阶段的心智成长 再读仓央嘉措《那一世》 人类,只有一个地球作文600字 最美的景色是好心情! 如何做好群众工作心得体会500字 过程是风景,结局是明信片 太吵了 蝶仙NO.1(人物介绍,序)作文400字 出纳年度财务统计工作总结 高新消防科开展年全员岗位大练兵活动实施计划 奇妙的饭碗作文400字 过年了,真累作文800字 怀恋那时的我们作文400字 瞬间的真情作文1600字 繁华随想作文700字 乡村秋色 读《小白兔好委屈》有感 高中高一作文900字:我拥有,我快乐 社区2013年年终工作总结 2016清明节是几月几号农历还是阳历 一堂快乐的“拆字”课1000字 在创新中崛起渔业监督在祖国成立周年演讲

Copyright © 2016 phpStudy |