如何从表中删除行,其中列包含子字符串,但该列的类型为“Long”。(是的,我知道我不应该使用 Long,但我在维护别人的烂摊子)。
我的第一次尝试是:
delete from longtable
where search_long(rowid) like '%hello%';
(从这个答案开始。)
这将返回:
SQL 错误:ORA-04091:表 blah.longtable 正在变异,触发器/函数可能看不到它
我刚刚复制了您的问题并得到了同样的错误 - 似乎该函数无法在 DELETE 语句中工作。错误的全文是:
ORA-04091: table HOU.LONGTABLE is mutating, trigger/function may not see it
ORA-06512: at "TONY.SEARCH_LONG", line 4
这种程序方法将起作用:
begin
for r in (select id from longtable
where search_long(rowid) like '%hello%')
loop
delete longtable where id = r.id;
end loop;
end;