Oracle数据库优化策略总结
SELECT时不利用函数
在做频繁的查询垄断时,尽量直接select字段名,然后利用C语言代码对查询收获做二次加工,避免让Oracle来做混杂的函数可能数学计算。因为Oracle出于通用性的琢磨,其函数及数学计算的速度远不及用C语言直接编译成机器码后计算来的快。
绑定变量
这个能够大幅度减退SQL的“hard parse”,我们大局部过程都曾经告终了变量绑定。个别未曾告终的,修正一下,也能很快看到收获。
批量FETCH
万一顺次select会归来多条(几百、上千)登记,利用批量Fetch,例如顺次fetch 1000条登记,要比一条条的fetch数据快的多,也能够管用减退oracle的压力。
批量提交
顺次修正多条(例如小于10000条左右)登记,然后顺次性提交,要比每条提交顺次快的多。当然前提是业务逻辑批准这么做。
批量增删改
万一必需顺次性修正可能剔除多条登记,能够批准批量数组绑定的.措施,这个和前面说得“绑定变量”相仿,差异是前者绑定的是一个变量,这里绑定的是一个大数组的首指针,这种措施要比逐条绑定厉行快的多。
SQL预解析
前面的大局部是批量垄断,还有一种常见的场景是小事务垄断,但频率极其高。这种场景等闲SQL也不混杂,几乎未曾优化的余地了,然而由于垄断频繁,同样会构成CPU居高不下。现在我们的过程大局部都是下面这个利用形式:
loop parse sql; bind var; execute sql; end loop;
固然我们利用了绑定变量的措施,然而由于垄断频繁,同样构成许多的“soft parse”以及网络通信。在内存数据库中,我们等闲批准预解析的措施来长进效率,事实上,Oracle很早就给开发者供给这种形式,只是开发者嫌繁琐没利于用而已。将过程改成下列形式:
parse sql; bind var; loop execute sql; end loop;
这么就能够管用减退Oracle的压力,能够将厉行效率起码长进一倍。然而这种形式波及到过程构造的改变,定然在设计阶段就这么做。否则,后期再调剂的话,危险和工作量都会很大。
SQL语句的一些优化措施
1、SQL语句用大写的;因为Oracle总是先解析SQL语句,把小写的字母转换成大写的再厉行。
2、避免在索引列上利用NOT等闲,我们要避免在索引列上利用NOT, NOT会发生在和在索引列上利用函数雷同的波及。
3、当Oracle“碰到”NOT,他就会静止利用索引转而厉行全表扫描。
4、避免在索引列上利用计算。WHERE子句中,假定索引列是函数的一局部。优化器将不利用索引而利用全表扫描。
5、尽量少用DISTINCT垄断,用EXISTS轮换DISTINCTvalues should never be negative。
-
系统工作会会议通知
会议通知是会议准备工作的重要一环。会议通知由标题、正文和落款三部分组成。今天小编为大家准备了系统工作会会议通知,欢迎阅读!系统工作会会议通知【1】所属各单位:为了总结交流经验,研究分析存在的问题,进一步贯彻落实省、市计划生育工作会议精神,做好今年计划生...
-
玩家攻略系统800字作文
“恭喜玩家,完成攻略任务获取飞行功能,玩家请注意,5天后将进入下一个攻略,请好好安排时间”,晓晓现在已经可以想象到自己在天空自由飞翔了。不过晓晓心中有个疑问:“男配貌似没有完成任务的说。”系统君弱弱的说了一句:”本系统维修中,抱歉玩家,下一攻略才继续有男配任...
-
小白一键重装系统步骤
小白一键重装系统工具是一款全新的一键GHOST重装系统软件,本软件为绿色版本,无需安装,无需U盘,更不需光驱、光盘,window系统镜像采用云高速同步下载功能,真真正正实现了一键重装系统功能,即使无任何电脑基础的用户也能快速重装系统,进行系统恢复、系统备份、系统还原。...
-
w7系统电脑亮度怎么调
现在有许多人都喜欢用win7系统的电脑,但是电脑亮度怎么调呢?下面是小编带来的win7台式机怎么调显示器亮度的'内容,欢迎阅读!Win7台式电脑调整屏幕亮度方法1、在电脑桌面空白鼠标右键,选择“屏幕分辨率”。2、在屏幕分辨率界面找到并选择“高级设置”。3、打开高...