首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >ORA-30926:无法在源表中获取稳定的行集

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

Stack Overflow用户
提问于 2010-02-26 04:14:00
回答 6查看 484.2K关注 0票数 144

我得到了

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

在以下查询中:

代码语言:javascript
复制
  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),它也包含数据。

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

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2010-02-26 04:42:30

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

您可以通过在查询中使用DISTINCT来快速解决这个问题(实际上,如果'Y‘是一个常量值,您甚至不需要将其放入查询中)。

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

代码语言:javascript
复制
  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';
票数 220
EN

Stack Overflow用户

发布于 2010-02-26 04:21:03

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

票数 44
EN

Stack Overflow用户

发布于 2016-04-02 05:44:33

如何排除ORA-30926错误?(文档ID 471956.1)

1)识别失败的语句

alter session set events‘30926跟踪名称错误堆栈级别3’;

alter system set events‘30926跟踪名称错误堆栈关闭’;

并在发生这种情况时注意UDUMP中的.trc文件。

2)找到SQL语句后,检查它是否正确(可能使用explain plan或tkprof检查查询执行计划),如果最近没有这样做,则分析或计算相关表的统计数据。重建(或删除/重新创建)索引也可能有所帮助。

3.1) SQL语句是MERGE吗?评估USING子句返回的数据,以确保联接中没有重复值。修改merge语句以包含确定性where子句

3.2)这是通过视图的UPDATE语句吗?如果是这样,请尝试将视图结果填充到表中,并尝试直接更新表。

3.3)桌子上有触发器吗?尝试禁用它,看看它是否仍然失败。

3.4)语句中是否包含' in -Subquery‘中的不可合并视图?如果查询具有"FOR UPDATE“子句,这可能会导致返回重复的行。请参阅Bug 2681037

3.5)表中是否有未使用的列?删除这些可能会防止错误。

4)如果修改SQL不能修复错误,那么问题可能出在表上,特别是在存在链接行的情况下。4.1)在SQL中使用的所有表上运行‘ANALYZE TABLE VALIDATE STRUCTURE CASCADE’语句,查看表或其索引中是否有任何损坏。4.2)检查并消除表上任何链接或迁移的行。有一些方法可以最小化这一点,例如正确设置PCTFREE。使用注释122020.1 -行链接和迁移4.3)如果表另外组织了索引,请参阅:注释102932.1 -监视IOT上的链接行

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2337271

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档