加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 使用dbUnit模拟触发器

发布时间:2020-12-15 02:27:52 所属栏目:Java 来源:网络整理
导读:我正在使用dbUnit将测试数据放入数据集中的数据库中 dataset TABLE_1 PRIMARY_KEY_COL="10000001" OTHER_COL="Some Text"/ /dataset 我的问题是db中的插入触发器将子记录填充到TABLE_2中.所以,当我尝试 DatabaSEOperation.DELETE.execute(); 在tearDown(),它
我正在使用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>

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读