使用dbUnit模拟触发器

时间:2011-09-05 16:02:49

标签: java oracle testing dbunit

我正在使用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中添加触发器?

2 个答案:

答案 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)