Oracle数据库进行简单优化,oracle数据库优化笔记

1 选择最有效率的表明顺序 一对多关系的表 一放在前面

2 where子句的链接顺序 表之间的连接条件必须写在其他WHERE条件之前,那些可以过滤最大数量记录的条件必须写在WHERE子句的末尾。

3 select语句中避免使用 * 。

4 减少访问数据库的次数。

5 如果有几个简单的数据库查询访问,可以把它们整合到一个查询中(即使他们没有任何关系

6 最高效的删除重复记录方法 ( 因为使用了 ROWID) 例子:

DELETE FROM EMP E WHERE E.ROWID > (SELECT MIN(X.ROWID)

FROM EMP X WHERE X.EMP_NO = E.EMP_NO);

7 当在 SQL 语句中连接多个表时,请使用表的别名并把别名前缀于每个表的Column 上。这样一来,就可以减少解析的时间并减少那些由 Column 歧义引起的语法错误。

8 当提交一个一对多关系查询时,避免在selcet语句中使用distinct,一般考虑用exist,它使查询更迅速。

( 低效 ):

SELECT DISTINCT DEPT_NO,DEPT_NAME FROM DEPT D , EMP E

WHERE D.DEPT_NO = E.DEPT_NO

( 高效 ):

SELECT DEPT_NO,DEPT_NAME FROM DEPT D WHERE EXISTS ( SELECT ‘X'

FROM EMP E WHERE E.DEPT_NO = D.DEPT_NO ) ;

9 sql 语句使用大写 先转成大写在执行。

10 java代码中少使用+来连接字符串。

11 尽量不适用操作符<> 它不会用到索引,因此它的处理只会产生全表扫描。可以使用其他相同操作符进行替换。

举例:a<>0 改为 a>0 or a<0

a<>’’ 改为 a>’’

12 使用索引可以加快数据库查询速度,

13 我们要避免在索引列上使用 NOT, NOT 会产生在和在索引列上使用函数相同的影响。当 ORACLE遇到NOT时, 他就会停止使用索引转而执行全表扫描

14 WHERE 子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描。

低效:

SELECT … FROM DEPT WHERE SAL * 12 > 25000;

高效:

SELECT … FROM DEPT WHERE SAL > 25000/12;

15 大于或小于操作符一般情况下是不用调整的,因为它有索引就会采用索引查找,但有的情况下可以对它进行优化,如一个表有100万记录,一个数值型字段A,30 万记录的A=0,30万记录的A=1,39万记录的A=2,1万记录的A=3。那么执行A>2与A>=3的效果就有很大的区别了,因为 A>2时sql会先找出为2的记录索引再进行比较,而A>=3时sql则直接找到=3的记录索引。

16 平常情况下,用 UNION 替换 WHERE 子句中的OR将会起到较好的效果。对索引列使用 OR 将造成全表扫描。注意,以上规则只针对多个索引列有效。如果有 column 没有被索引,查询效率可能会因为你没有选择 OR 而降低。

在下面的例子中 ,LOC_ID 和 REGION 上都建有索引。

高效 :

SELECT LOC_ID , LOC_DESC , REGION

FROM LOCATION

WHERE LOC_ID = 10

UNION

SELECT LOC_ID , LOC_DESC , REGION

FROM LOCATION

WHERE REGION = “ME

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值