DB2删除数据慢解决方法

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-07 17:17:19
オリジナル
2021 人が閲覧しました

db2有两张表,A主表 B从表,B的外键是A的主键 A B两个表数据量都超过百万, 删除A表的一条记录,用主键作为删除条件,时间有明

db2有两张表,A主表   B从表,B的外键是A的主键
A B两个表数据量都超过百万,
删除A表的一条记录,用主键作为删除条件,时间有明显的延迟。
如果用其他字段做where条件,一次删除目标为几百条,等了几分钟也没有删成功。

如果先删除B表应该关联删除的数据,删掉几百条也很快。但是再删A表数据还是不行。

分析原因,,删B表数据db2直接删了,所以快。
删A表数据的时候db2会先去B表查询关联记录,这样一次删除A表中目标为几百条记录的实际需要的操作是:
1  根据条件选出A表记录集合,a
2. 以a为驱动表,在B表中查询关联记录,并记录结果为b
3. 删除B表中关联的数据b
4. 删除a
由于删除涉及到两张表,实际上从1到4的操作db2会自己加上事务,这样就慢了。

解决方法:
很简单,取消B的外键,然后删除就像闪电一样快了  :)

linux

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート