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 交通频道 作文范文 扶余北-蛟河西 沈阳-新县 苏州-虢镇 宿州东-合肥南 小东-上园 汾阳-乌鲁木齐 巩义-九江 武汉-襄阳 一面山-边沟 武当山-绵阳 南昌西-缙云西 定西-江油 大余-源潭 侯马-安顺 宁德-深圳北 宣威-郑州 鹰潭北-新晃西 兰棱-清河城 桥头-清原 内江-施秉 威海-莱西北 本溪-陈相屯 丹东-汤山城 无锡-罗山 郴州-绩溪县 小榄-古镇 甘旗卡-开通 襄阳-金华 苏集-姑家堡 张家口南-景泰 渑池-阜阳 安富镇-广顺场 泾县-诏安 霸州-大同 略阳-新安县 江津-隆昌 陆川-化州 高平-晋城北 平顶庙-达日其嘎 康金井-扎兰屯 鲘门-福清 固原-渭南 昌图西-青岛北 天岗-哈尔巴岭 东来-密云北 张三营-三把火 南京-泰和 青县-大虎山 庐江-株洲 铜仁-深圳西 荆门-张家界 新干-阳新 对青山-乌尔旗汗 武威-潼关 丹东-本溪新城 聊城-哈尔滨西 宿松-黄梅 长沙-曹县 石嘴山-酒泉 荆门-当阳 济南东-双城堡 张台子-辽阳 沁河北-修武 清水-巢湖 奇峰塔-小西庄 长寿北-信阳东 永州-双峰北 嘉兴南-芷江 大英东-金寨 清河城-虞城县 河唇-威舍 咸阳-乌鲁木齐南 娄底南-广州南 金山卫-春申 余姚-松江 巢湖东-武夷山北 文水-武乡 锦州-蕲春 松江南-龙岩 柳江-苍溪 从北京到蓬莱怎么坐车合适
在淮安市新客车南站可以买到“淮安—南通”的客车票吗提前几天可以买到
青县到安阳怎么坐车
求《水浒传》快餐,应付考试
澄海汽车总站坐什么公车到潮州市内
从东北农业大学到哈尔滨市119中坐公交怎么坐车
禹州哪些快递公司的快递能到龙岗电厂
27号能买到当天的列车火车票,那到广州的时间是上午还是下午
盐城今年的会计从业资格证书 ,财经法规和会计基础考试是笔试
上饶到无锡高速怎么坐车
谁知道青岛城阳区哪里有到济宁的物流公司啊
呼和浩特 饭店40到50人 去哪里合适
上海到重庆坐汽车客车需要多长时间..票价大概多少啊?
深圳到潮州的搬家公司大概要票价多少钱呀 50铃的货车..
怎么从武汉天河机场坐车到武广高速武汉新站
广州西列车火车站有没有到深圳的列车火车没有的话怎么坐什麽车去深圳
武汉有到马鞍山的汽车吗
今年五一虎跃快客从沈阳到葫芦岛的票价是多少钱啊
肇庆到珠海香洲总站,每天下午都有车吗大概要坐多少小时
常州黄河西路218号坐几路车能到急
从通化到南京有直达的列车吗
请推荐新加坡, 可以吃到当地美食的地方
渭南火车列车站订票电话是什么★¢★★
从河北廊坊到山东济宁驾车需要经过哪些省市
请问有没有从江苏镇江直达山东聊城的火车或者汽车
天津老干部俱乐部坐什么车去
从淮安信息学院想去周恩来故居怎么走啊?去纪念馆又怎么走啊?
南昌到丰城的线路 列车火车 汽车
苗族的节日、习俗或活动
从广州坐火车到甘肃天水多少小时

Copyright © 2016 phpStudy |