第一种方法:
1. 删除表间的关联
select 'alter table '||table_name||' drop constraint '||constraint_name||' cascade;' from user_constraints where owner = '用户';
DECLARE
TYPE name_list IS TABLE OF VARCHAR2(40);
TYPE type_list IS TABLE OF VARCHAR2(20);
Tab_name name_list:=name_list();
Tab_type type_list:=type_list();
sql_str VARCHAR2(500);
BEGIN
sql_str := 'select uo.object_name,uo.object_type from user_objects uo where uo.object_type not in(''INDEX'',''LOB'') order by uo.object_type desc';
EXECUTE IMMEDIATE sql_str BULK COLLECT INTO tab_name,tab_type;
FOR i IN Tab_name.FIRST.. Tab_name.LAST LOOP
sql_str := 'DROP ' || Tab_type(i) || ' ' || Tab_name(i);
EXECUTE IMMEDIATE sql_str;
END LOOP;
END;
第二种方法:
直接删除用户...
drop tablespace XXXX INCLUDING CONTENTS;
drop user XXXX cascade;
本文提供两种批量删除Oracle数据库中特定用户及其所有对象的方法。第一种方法通过SQL脚本解除表间关联并删除对象;第二种方法直接删除用户及其表空间内容。
1361

被折叠的 条评论
为什么被折叠?



