Ora-30926:无法在源表中获得一组稳定的行

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (44)

我得到一个报错

ORA-30926: unable to get a stable set of rows in the source tables

在以下查询中:

  MERGE INTO table_1 a
      USING 
      (SELECT a.ROWID row_id, 'Y'
              FROM table_1 a ,table_2 b ,table_3 c
              WHERE a.mbr = c.mbr
              AND b.head = c.head
              AND b.type_of_action <> '6') src
              ON ( a.ROWID = src.row_id )
  WHEN MATCHED THEN UPDATE SET in_correct = 'Y';

我已经运行table_1,它有数据,而且我运行了src也有数据的内部查询()。

为什么会出现这个错误,如何解决?

提问于
用户回答回答于

这通常是由USING子句中指定的查询中的重复项引起的。这可能意味着TABLE_A是父表,并且多次返回相同的ROWID。

你可以通过在你的查询中使用DISTINCT来快速解决问题(事实上,如果'Y'是一个常数值,你甚至不需要把它放在查询中)。

假设你的查询是正确的(不知道你的表),你可以做这样的事情:

  MERGE INTO table_1 a
      USING 
      (SELECT distinct ta.ROWID row_id
              FROM table_1 a ,table_2 b ,table_3 c
              WHERE a.mbr = c.mbr
              AND b.head = c.head
              AND b.type_of_action <> '6') src
              ON ( a.ROWID = src.row_id )
  WHEN MATCHED THEN UPDATE SET in_correct = 'Y';
用户回答回答于

你可能试图多次更新目标表的同一行。我刚刚在我开发的合并语句中遇到了同样的问题。确保你的更新不会在执行合并时多次接触同一记录。

扫码关注云+社区