当前位置:Gxlcms > 数据库问题 > 通过在Oracle子表外键上建立索引提高性能

通过在Oracle子表外键上建立索引提高性能

时间:2021-07-01 10:21:17 帮助过:15人阅读

1)如果更新了父表的主键(倘若遵循关系数据库的原则,即主键应当是不可变的,这种情况就很少见),由于外键上没有索引,所以子表会被锁住。 2) 如果删除了父表中的一行,整个子表也会被锁住(由于外键上没有索引)。   除了全表锁外,在以下情况下,未加索引的外键也可能带来问题: 1) 如果有ON DELETE CASCADE,而且没有对子表加索引:例如,EMP是DEPT的子表,DELETE DEPTNO = 10应该CASCADE(级联)至EMP。如果EMP中的DEPTNO没有索引,那么删除DEPT表中的每一行时都会对EMP做一个全表扫描。这个全表扫 描可能是不必要的,而且如果从父表删除多行,父表中每删除一行就要扫描一次子表。 2) 从父表查询子表:再次考虑EMP/DEPT例子。利用DEPTNO查询EMP表是相当常见的。如果频繁地运行以下查询(例如,生成一个报告),你会发现没有索引会使查询速度变慢: ?? select * from dept, emp ?? where emp.deptno = dept.deptno and dept.deptno = :X;   那么,什么时候不需要对外键加索引呢?答案是,一般来说,当满足以下条件时不需要加索引: 1) 没有从父表删除行。 2) 没有更新父表的惟一键/主键值(当心工具有时会无意地更新主键!)。 3) 没有从父表联结子表(如DEPT联结到EMP)。   转载:http://blog.itpub.net/24104518/viewspace-716784/

通过在Oracle子表外键上建立索引提高性能

标签:主键   位图   修改   select   关系   问题:   nbsp   ace   多行   

人气教程排行