Oracel的外键不会自动建立索引,数据量大时应该手工建立索引

 

今天调了几个sql,发现一个容易误解的问题,那就是Oracle的外键跟主键不一样,并不会自动建立索引,大家不要误会,Oracle外键只是增加了一个约束,并不会像主键那样自动建立索引,这样我们编程序时总认为用外键查询子表数据天经地义就应该很快,可实际上当数据量很大时,通过外键查询子表数据会非常缓慢。

例如如下sql(实际sql类似,就不完整写了):

select * from t1 where t_id in (

        select t_id from t where xxx like 'xxx%'

);

实际上t主表有几百万数据,t1子表有个几千万数据,其实数据量并不算大,但查询速度非常慢,要10几秒。分析执行计划,发现oracle居然用两表的full acces查询的。

原来是t1的外键t_id上没有索引,加上以后,在查询使用了这个索引,虽然主表仍然用full access了,但整个查询0.4秒就出结果了。在优化还需要主表上再加索引啥的了。

 

需要考虑的一点是:Oracle默认没有给外键自动加上索引肯定是有他的考虑的,最好还是表数据量大了再加,没必要统一全加上,谁知道会有啥咱没注意到的别问题呢。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值