我需要更新oracle数据库中所有表中与特定模式匹配的列。例如,我在所有表中都有这个列*_CID,它是主表的外键,它有一个主键CID
感谢
您可以使用命名约定并查询all_tab_columns
declare
cursor c is
select table_owner , column_name, table_name from all_tab_columns where column_name like '%_CID';
begin
for x in c loop
execute immediate 'update ' || x.table_owner || '.' || x.table_name ||' set ' || x.column_name||' = 0';
end loop;
end;
如果您有有效的Fk,您也可以使用all_tab_constraints
(为主表启用了提取功能的Fk),并提取r_constraint_name
的列名。
我找到了一个解决问题的方法:
BEGIN
FOR x IN (SELECT owner, table_name, column_name FROM all_tab_columns) LOOP
EXECUTE IMMEDIATE 'update ' || x.owner || '.' || x.table_name ||' set ' || x.column_name||' = 0 where '||x.column_name||' = 1';
END LOOP;
END;
感谢