Oracel的外键不会自动建立索引,数据量大时应该手工建立索引
2015-09-07 16:43
531 查看
今天调了几个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默认没有给外键自动加上索引肯定是有他的考虑的,最好还是表数据量大了再加,没必要统一全加上,谁知道会有啥咱没注意到的别问题呢。
相关文章推荐
- 基于 Red Hat 的发行版 Oracle Linux 正式发布Oracle Linux 7.1
- Oracle Containers for J2EE远程安全漏洞(CVE-2014-0413)
- Oracle 10g R2不能使用EM的问题
- 表空间操作
- PreparedStatement中in子句的处理
- VMware下RedHat4.8_64位安装Oracle 10g RAC--简略脚本
- oracle sql日期比较
- 基于 Red Hat 的发行版 Oracle Linux 正式发布Oracle Linux 7.1
- OS block size和Oracle block size,查找OS Blocksize的方法
- oracle中创建数据库和表空间的几点总结
- 数据库自动备份脚本
- oracle的nvl函数的使用介绍
- 解决oracle用户连接失败的解决方法
- oracle的一些tips技巧
- Oracle 下的开发日积月累
- Oracle存储过程之数据库中获取数据实例
- Windows下ORACLE 10g完全卸载的方法分析
- Oracle 函数大全[字符串函数,数学函数,日期函数]第1/4页
- ORACLE LATERAL-SQL-INJECTION 个人见解