我正在使用dbUnit将测试数据放入数据集中的数据库中
<dataset>
<TABLE_1 PRIMARY_KEY_COL="10000001" OTHER_COL="Some Text"/>
</dataset>
我的问题是db中的插入触发器将子记录填充到TABLE_2中.所以,当我尝试
DatabaseOperation.DELETE.execute();
在tearDown(),它失败了java.sql.SQLException:ORA-02292:违反了完整性约束(TABLE_2_TABLE_1_FK) – 找到了子记录.
有没有办法模拟TABLE_1的on-delete触发器,用dbUnit删除子记录,不要在DB中添加触发器?
解决方法:
我们的数据库中没有触发器,但我们确实使用dbunit,这可能对您有用:
您可以为DELETE操作提供不同的数据集,其中包括触发器将数据插入的表.顺序很重要,因此dbunit可以对首先引用TABLE_1的表执行删除或插入操作…
<dataset>
<TABLE_WITH_TRIGGERED_DATA_HERE...>
<TABLE_1 PRIMARY_KEY_COL="10000001" OTHER_COL="Some Text"/>
</dataset>