添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
登录

ORA-30926:无法在源表中获取稳定的行集

内容来源于 Stack Overflow,遵循 CC BY-SA 4.0 许可协议进行翻译与使用。IT领域专用引擎提供翻译支持

腾讯云小微IT领域专用引擎提供翻译支持

原文
Stack Overflow用户 修改于2016-03-10
  • 该问题已被编辑
  • 提问者: Stack Overflow用户
  • 提问时间: 2010-02-26 04:14

我得到了

ORA-30926:无法在源表中获取稳定的行集

在以下查询中:

  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 ),它也包含数据。

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

浏览 289 关注 0 得票数 144
  • 得票数为Stack Overflow原文数据
原文
回答于2010-02-26
得票数 44

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

回答于2010-02-26
得票数 220

这通常是由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