Oracel的外键不会自动建立索引,数据量大时应该手工建立索引
来源:互联网 发布:联想网络控制程序密码 编辑:程序博客网 时间:2024/06/11 22:05
今天调了几个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默认没有给外键自动加上索引肯定是有他的考虑的,最好还是表数据量大了再加,没必要统一全加上,谁知道会有啥咱没注意到的别问题呢。
0 0
- Oracel的外键不会自动建立索引,数据量大时应该手工建立索引
- Hibernate Search大数据量手动建立索引
- 如何优化操作大数据量数据库(建立索引)
- 如何优化操作大数据量数据库(建立索引)
- mysql给创建的外键自动建立索引吗?
- MySQL建立索引应该注意的事项
- 大表建立索引
- ORACLE库中 大数据量的表 中索引建立的注意事项
- oracle表数据量大时建立索引,需要加上online参数
- mysql建立索引的几大原则
- 为大数据表建立索引
- 索引视图的建立
- 索引的建立
- 索引视图的建立
- 索引建立的原则
- 建立索引的原则
- 建立索引的原则
- 索引的建立 实例
- Handler
- VPN技术概要
- 大学的多姿多彩。
- makefile 速成
- java-----时间
- Oracel的外键不会自动建立索引,数据量大时应该手工建立索引
- 第二周项目0 第一篇博文
- 项目0—NO.1
- c/c++语言中函数参数传递的三种方式——徐吉平
- OneNote 的一种模拟方法(上)
- 一个最简单的Makefile例子
- 第2章 开始学习C++
- 20150907超级计算机程序
- HDU - 3313 Key Vertex(在最短路上的DFS)