我正进入(状态
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返回多次。
原文链接:https://www.f2er.com/oracle/208833.html您可以在查询中使用DISTINCT来快速解决问题(实际上,如果“Y”是一个常量值,您甚至不需要将其放在查询中)。
假设你的查询是正确的(不知道你的表),你可以这样做:
MERGE INTO table_1 a USING (SELECT distinct ta.ROWID row_id FROM table_1 a,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';