java – 使用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中添加触发器?

解决方法:

我们的数据库中没有触发器,但我们确实使用dbunit,这可能对您有用:

您可以为DELETE操作提供不同的数据集,其中包括触发器将数据插入的表.顺序很重要,因此dbunit可以对首先引用TABLE_1的表执行删除或插入操作…

<dataset>
    <TABLE_WITH_TRIGGERED_DATA_HERE...>
    <TABLE_1 PRIMARY_KEY_COL="10000001" OTHER_COL="Some Text"/>
 </dataset>
上一篇:mysqldump xml格式和dbunit预期在phpunit测试中的xml格式


下一篇:java – org.hibernate.event.def.EventCache不支持null实体是什么意思?