大量データの投入テスト後、再テストのためなどにデータの消し込みを行う場合、トランザクションログを出力させない TRUNCATE コマンドが便利です。
実際に高速でデータの削除が行えるため、すごく便利なコマンドなのですがマニュアルの「規則」の項に以下の記載があります。
参照整合性: 参照制約が適用される場合、表、および表階層内のすべての表は、親表であってはなりません (SQLSTATE 428GJ)。自己参照 RI 制約は許可されます。
https://www.ibm.com/support/knowledgecenter/ja/SSEPGG_11.5.0/com.ibm.db2.luw.sql.ref.doc/doc/r0053474.html
つまり外部参照制約の親表であってはダメという事なのですが、これってなかなかの制限ですよね。
子表との制約にずれが生じてしまうので仕方ないのですが、大量データの投入テスト時とかあまり気にしてませんよね?
今後参照制約を無視できるオプションとかできると嬉しいです。