Oracle数据库优化策略总结篇

   2015-10-09 0
核心提示:本文介绍了一些很实用但却不是很常见的Oracle数据库的优化策略,包括批量FETCH、SQL预解析等,需要的朋友可以参考下

为了提高查询效率,我们常常做一些优化策略。本文主要介绍一些Oracle数据库的一些不常见却是非常有用的优化策略,希望能对您有所帮助。

SQL语句优化

这个好办,抓到挪借CPU高的SQL语句,依据索引、SQL技巧等修改一下,行之管用。

SELECT时不利用函数

在做频繁的查询垄断时,尽量直接select字段名,然后利用C语言代码对查询收获做二次加工,避免让Oracle来做混杂的函数可能数学计算。因为Oracle出于通用性的琢磨,其函数及数学计算的速度远不及用C语言直接编译成机器码后计算来的快。

绑定变量

这个能够大幅度减退SQL的“hard parse”,我们大局部过程都曾经告终了变量绑定。个别未曾告终的,修正一下,也能很快看到收获。

批量FETCH

万一顺次select会归来多条(几百、上千)登记,利用批量Fetch,例如顺次fetch 1000条登记,要比一条条的fetch数据快的多,也能够管用减退oracle的压力。

批量提交

顺次修正多条(例如小于10000条左右)登记,然后顺次性提交,要比每条提交顺次快的多。当然前提是业务逻辑批准这么做。

批量增删改

万一必需顺次性修正可能剔除多条登记,能够批准批量数组绑定的措施,这个和前面说得“绑定变量”相仿,差异是前者绑定的是一个变量,这里绑定的是一个大数组的首指针,这种措施要比逐条绑定厉行快的多。

SQL预解析

前面的大局部是批量垄断,还有一种常见的场景是小事务垄断,但频率极其高nextplas.com。这种场景等闲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。

以上就是Oracle数据库的优化策略的全部,如果您想了解更多关于Oracle数据库的知识,那就关注Oracle数据库栏目,相信会对您有所收获的。

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • Oracle迁移到MySQL性能下降的注意点 oracle数据
    背景:最近有较多的客户系统由原来由Oracle改造到MySQL后出现了性能问题CPU 100%,或是后台的CRM系统复杂SQL在业务高峰的时候出现堆积导致业务故障。在我的记忆里面淘宝最初从Oracle迁移到MySQL期间也遇到了很多SQL的性能问题,记忆最为深刻的子查询,当初的
    02-10
  • oracle数据库按照日期排序后获取第一条数据SQL
    select *from (select * from 表名 where 条件 order by 排序日期 desc) where rownum=1;  select *  from (select * from TABLE where STATE = 3 order by TIME desc) where rownum=1;
    02-10
  • Oracle数据库列出所有表名SQL语句 oracle查询表
     select table_name from user_tables
    02-10
  • oracle基础sql语句详解 oracle数据库语法大全
    【转】 oracle基础sql语句详解2011-11-26 12:40转载自 分享最终编辑 liwei5083二、SQL   Structur query language      结构化查询语言,是操作关系型数据库中的对象。          DDL(Data definition language 数据定义语言),用于建表或删表
    02-10
  • Oracle与SQL自治事务 oracle数据库事务
    自治事务是独立的事务操作,如果考虑到事务回滚,必须单独写成一个触发器来完成,一个事务A在另一个事务B内被调用,那个事务A是自治事务,自治事务A执行过程中会脱离其session内未执行完毕的事务的影响。如果session从B事务开始——A事务开始和结束——B事务
    02-10
  • ORACLE数据库sql语句时间戳转时间 oracle数据库
    SELECT TO_CHAR(ADDTIME/ (60 * 60 * 24) + TO_DATE('1970-01-01 08:00:00', 'YYYY-MM-DD HH24:MI:SS'), 'YYYY-MM-DD HH24:MI:SS') AS TESTDATE  FROM TIMWIN其中“HH24:MI:SS”为24小时制
    02-10
  • springcloud适配mysql和oracle数据库 springclo
    mysql和oracle数据库部分语法不相同,为了适配两种数据库(修改配置文件方式),可以先操作sql,然后通过代码级别再实现。比如oracle限制返回的条数:rownum=1 但是mysql的语法是:limit 1,你可以通过返回所有数据,然后再get(0)去除第一条数据,今天的重点:
    02-10
  • Oracle:SQL语句--给用户赋权限 oracle数据库用
    ——给用户赋予权限 ——权限和角色 为了简化权限管理,引入了角色的概念,角色是具有名称的一组权限的组合 ——常用系统预定义角色 ——connect:临时用户 ——resource:更为可靠和正式的用户 ——DBA:数据库管理员角色,拥有管理数据库的最高权限——分配
    02-10
  • 搜索表字段包含某字符串的SQL和监控Oracle数据
    1.第一个SQL背景:需要找到SQL Server数据库中,包含某个字符串的表,输出表和包含该字符串的列。DECLARE @string VARCHAR(100)='=' --这里填要搜索的字符串DECLARE @sql NVARCHAR(MAX)SET @sql=N'DECLARE @sql NVARCHAR(MAX),@ColNames NVARCHAR(MAX),@ColVal
    02-10
  • SQL语句往Oracle数据库中插入日期型数据(to_da
     Oracle 在操作数据库上相比于其他的 T-sql 有微小的差别,但是在插入时间类型的数据是必须要注意他的 to_date 方法,具体的情况如下:--SQL语句往Oracle数据库中插入日期型数据(to_date的用法)INSERTINTOFLOORVALUES( to_date ( '2007-12-20 18:31:34' ,
    02-10
点击排行