为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

慕容3067478 2019-08-02 16:33:23
ORA-30926:无法在源表中获得稳定的行集我正进入(状态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)也有数据。为什么会出现此错误以及如何解决?
查看完整描述

3 回答

?
Cats萌萌

TA贡献1805条经验 获得超9个赞


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


查看完整回答
反对 回复 2019-08-02
?
偶然的你

TA贡献1841条经验 获得超3个赞

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


查看完整回答
反对 回复 2019-08-02
?
摇曳的蔷薇

TA贡献1793条经验 获得超6个赞

如何排除ORA-30926错误?(文件号471956.1)

1)识别失败的陈述

alter session set events'30926 trace name errorstack level 3';

要么

alter system set events'30926 trace name errorstack off';

并在UDUMP发生时监视.trc文件。

2)找到SQL语句后,检查它是否正确(可能使用说明计划或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)检查并消除表中的任何CHAINED或迁移的ROWS。有一些方法可以最大限度地减少这种情况,例如正确设置PCTFREE。使用说明122020.1 - 行链接和迁移4.3)如果表另外是索引组织,请参阅:注释102932.1 - 监视IOT上的链接行


查看完整回答
反对 回复 2019-08-02
  • 3 回答
  • 0 关注
  • 2898 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信