Sql 删除与LIKE匹配的子字符串的行?

Sql 删除与LIKE匹配的子字符串的行?,sql,oracle,sql-like,sql-delete,ora-04091,Sql,Oracle,Sql Like,Sql Delete,Ora 04091,如果列包含子字符串,但该列的类型为“Long”,如何从表中删除行。(是的,我知道我不应该用很长时间,但我在维护别人的烂摊子) 我的第一次尝试是: delete from longtable where search_long(rowid) like '%hello%'; (下接自) 这将返回: SQL错误:ORA-04091:表blah.longtable正在变异,触发器/函数可能看不到它 我刚刚复制了您的问题,并得到了相同的错误-似乎函数无法在DELETE语句中工作。错误全文如下:

如果列包含子字符串,但该列的类型为“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;