今天 ,Cisco的MES表中遇到了一个执行效率很慢的问题,发现主表和子表关联时使用了外键,但是当外键缺失索引,子表进行全表扫描。遇到使用外键的情况,要检查一下外键是否已经建立索引。
在ORACLE数据库中,定义外键约束时,ORACLE是不会自动创建对应索引的,必须手动在外键约束相关的列上创建索引。
外键列上缺少索引会带来:限制并发性、影响查询性能等问题。
1. 影响查询性能。 如果子表外键没有创建索引,那么当父表查询关联子表时,子表将进行全表扫描。
2. 影响并发。 无论是更新父表主键,或者删除一个父记录,都会在子表中加一个表锁(在这条语句完成前,不允许对子表做任何修改)。同样,如果子表外键没有创建索引,那么在子表进行DML操作时,将会锁住整个父表。影响并发性。
Oracle外键的索引影响
最新推荐文章于 2024-05-05 02:58:38 发布