oracle 使用别名过慢,oracle 优化经验分享

17.7、用“>=”替代“>”

大于或小于操作符一般情况下是不用调整的,因为它有索引就会采用索引查找,但有 的情况下可以对它进行优化,如一个表有 100 万记录,一个数值型字段 A,  30 万记

Oracle 教程

录的 A=0,30 万记录的 A=1,39 万记录的 A=2,1 万记录的 A=3。那么执行 A>2 与 A>=3 的效果就有很大的区别了,因为  A>2 时 ORACLE 会先找出为 2 的记录索引再 进行比较,而 A>=3 时 ORACLE 则直接找到=3 的记录索引

17.8、利用 SGA 共享池,避开 parse 阶段

同一功能同一性能不同写法 SQL 的影响 如一个 SQL 在 A 程序员写的为

Select * from zl_yhjbqk

B 程序员写的为

Select * from dlyx.zl_yhjbqk(带表所有者的前缀)

C 程序员写的为

Select * from DLYX.ZLYHJBQK(大写表名)

D 程序员写的为

Select *   from DLYX.ZLYHJBQK(中间多了空格)

以上四个  SQL  在  ORACLE  分析整理之后产生的结果及执行的时间是一样的,但是从 ORACLE 共享内存 SGA 的原理,可以得出 ORACLE 对每个 SQL  都会对其进行一次分析, 并且占用共享内存,如果将 SQL 的字符串及格式写得完全相同则 ORACLE 只会分析一次, 共享内存也只会留下一次的分析结果,这不仅可以减少分析 SQL 的时间,而且可以减少共 享内存重复的信息,ORACLE 也可以准确统计 SQL 的执行频率。

不同区域出现的相同的 Sql 语句要保证查询字符完全相同,建议经常使用变量来代替常量, 以尽量使用重复 sql 代码,以利用 SGA 共享池,避开 parse 阶段,防止相同的 Sql 语句被 多次分析,提高执行速度。

因此使用存储过程,是一种很有效的提高 share pool 共享率,跳过 parse 阶段,提高效率的 办法。

17.9、WHERE 后面的条件顺序要求

WHERE 后面的条件,表连接语句写在最前,可以过滤掉最大数量记录的条件居后。 比如:

Select * from zl_yhjbqk where dy_dj = '1KV 以下' and xh_bz=1

Select * from zl_yhjbqk where xh_bz=1   and dy_dj = '1KV 以下'

以上两个 SQL 中 dy_dj(电压等级)及 xh_bz(销户标志)两个字段都没进行索引,所 以执行的时候都是全表扫描,第一条 SQL 的 dy_dj = '1KV 以下'条件在记录集内比率为 99%,

而 xh_bz=1 的比率只为 0.5%,在进行第一条 SQL 的时候 99%条记录都进行 dy_dj 及 xh_bz

Oracle 教程

的比较,而在进行第二条 SQL 的时候 0.5%条记录都进行 dy_dj 及 xh_bz 的比较,以此可以 得出第二条 SQL 的 CPU 占用率明显比第一条低。

17.10、使用表的别名,并将之作为每列的前缀

当在 Sql 语句中连接多个表时,使用表的别名,并将之作为每列的前缀。这样可以减少解 析时间

17.11、进行了显式或隐式的运算的字段不能进行索引

比如:

ss_df+20>50,优化处理:ss_df>30

„X‟||hbs_bh>‟X5400021452‟,优化处理:hbs_bh>‟5400021542‟

sk_rq+5=sysdate,优化处理:sk_rq=sysdate-5

hbs_bh=5401002554,优化处理:hbs_bh=‟  5401002554‟,注:此条件对 hbs_bh  进行隐 式的 to_number 转换,因为 hbs_bh 字段是字符型。

17.12、用 UNION ALL 代替 UNION

UNION 是最常用的集操作,使多个记录集联结成为单个集,对返回的数据行有唯一性要求, 所以 oracle 就需要进行 SORT UNIQUE 操作(与使用 distinct 时操作类似),如果结果集又 比较大,则操作会比较慢;

UNION  ALL 操作不排除重复记录行,所以会快很多,如果数据本身重复行存在可能性较

小时,用 union all 会比用 union 效率高很多!

17.13、其他操作

尽量使用 packages:  Packages 在第一次调用时能将整个包 load 进内存,对提高性能有帮 助。

尽量使用 cached sequences  来生成 primary key  :提高主键生成速度和使用性能。 很好地利用空间:如用 VARCHAR2  数据类型代替 CHAR 等

使用 Sql 优化工具:sqlexpert;toad;explain-table;PL/SQL;OEM

17.14、通过改变 oracle 的 SGA 的大小

SGA:数据库的系统全局区。

SGA 主要由三部分构成:共享池、数据缓冲区、日志缓冲区

racle 教程

1、 共享池又由两部分构成:共享 SQL 区和数据字典缓冲区。共享 SQL 区专门 存放用户 SQL 命令,oracle 使用最近最少使用等优先级算法来更新覆盖;数据字 典缓冲区(library cache)存放数据库运行的动态信息。数据库运行一段时间后, DBA 需要查看这些内存区域的命中率以从数据库角度对数据库性能调优。通过执 行下述语句查看:

select (sum(pins - reloads)) / sum(pins) "Lib Cache"   from   v$librarycache;

--查看共享 SQL 区的重用率,最好在 90%以上,否则需要增加共享池的大小。 select  (sum(gets  -  getmisses  -  usage  -  fixED))  /  sum(gets)  "Row  Cache"   from v$rowcache;

--查看数据字典缓冲区的命中率,最好在 90%以上,否则需要增加共享池的大小。

2、   数据缓冲区:存放 sql 运行结果抓取到的 data block;

SELECT   name,   value FROM   v$sysstat WHERE   name   IN   ('db   block   gets',

'consistent gets','physical reads');

--查看数据库数据缓冲区的使用情况。查询出来的结果可以计算出来数据缓冲区 的使用命中率=1 - ( physical reads / (db block gets + consistent gets) )。命中率应该

在 90%以上,否则需要增加数据缓冲区的大小。

3、 日志缓冲区:存放数据库运行生成的日志。

select   name,value   from   v$sysstat   where   name   in  ('redo  entries','redo  log  space requests');

--查看日志缓冲区的使用情况。查询出的结果可以计算出日志缓冲区的申请失败

率:申请失败率=requests/entries,申请失败率应该接近于 0,否则说明日志缓冲 区开设太小,需要增加 ORACLE 数据库的日志缓冲区。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值