【数据库】在外键上建立索引

在Oracle数据库中,未索引的外键可能导致锁表、全表扫描及连接查询速度下降,严重影响数据库并发性和性能。只有在特定条件下,才可避免为外键添加索引。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

出处:https://blog.youkuaiyun.com/qq_33762043/article/details/79961300

在oracle数据库中,当对父表(上面例子中的dep表)进行更新的时候,如果在子表(上面例子中的student表)中的外键没有使用索引,则在更新的过程中整个子表将被锁定,而往往实际上并不需要锁定整个子表,而仅仅需要锁定子表中的几条记录。这样就会大大影响数据库访问的并发性,甚至有可能造成死锁的情况。

除了锁表的问题之外,一个没有使用索引的外键在下面两种情况下表现的也十分糟糕:

当使用ON DELETE CASCADE删除父表中的记录时,如果在子表中的外键没有使用索引,则当执行该操作时,会对子表进行全表的扫描,而事实上这个全表的扫描是不需要的。更坏的情况是,如果删除多个父表中的记录,每删除一条记录则会进行一次全表扫描,可想而知,对于性能的影响是多么的大!
对于父表和子表的连接查询,情况也是类似的。当进行这种连接查询时,如果不对外键使用索引则会发现查询的速度大大降低。
这下你一定明白了为什么需要在外键上使用索引的重要意义了,不过你还是坚持不想使用索引的话,也可以,不过必须保证下面三种情况同时满足:

(1)不从父表中删除记录
(2)不更新父表中的主键的值
(3)一般不进行父表和子表的连接查询


如果你觉得可以满足上面的全部三个条件,那么可以不必为外键添加索引。但一般来讲,上面的三种情况很难满足,若不使用索引将会付出很大的代价。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值