oracle优化语句小结-持续更新

以下是本人的ORALCE语句小结:
1.使用SELECT 的时候,尽量不要使用 * 而是使用具体的列名。

2.避免在索引列上使用计算,或者使用函数。
WHERE 子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描.
低效 select id from t where num/2=100
应改为: select id from t where num=100*2

3.尽量在WHERE 条件小心使用NOT IN 和 IN,避免全表查询

4.最好能用 exists 代替 in
低效:SELECT * FROM NUM_1 WHERE A IN (SELECT B FROM NUM_2)
应改为:SELECT * FROM NUM_1 WHERE exists(SELECT B FROM NUM_2 WHERE A = B)

5.WHERE 条件是至下往上的执行,能过滤大量数据的条件写在最下面

6.FROM 后面的表格从右到左的顺序加载表数据,应该把可以排除数据最多的表放到后面(基础表)

7.批量执行INSERT/UPDATE的时候,要适当执行commit。避免写入缓存溢出导致语句语句一直执行等待。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值