我正在使用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中添加触发器?
答案 0 :(得分:1)
我们的数据库中没有触发器,但我们确实使用了dbunit,这可能对您有用:
您可以为DELETE操作设置不同的数据集,其中包括触发器将数据插入的表。顺序很重要,因此dbunit可以在首先引用TABLE_1的表上执行删除或插入操作...
<dataset>
<TABLE_WITH_TRIGGERED_DATA_HERE...>
<TABLE_1 PRIMARY_KEY_COL="10000001" OTHER_COL="Some Text"/>
</dataset>
答案 1 :(得分:0)