Oracle中,如何删除一个用户下的所有表
因为是连另一台机器,我现在又无法以管理员登录,所以无法直接删除重建用户,请问用SQL语句该如何删除一个用户下的所有表还有试图,函数,自定义数据类型,总之是所有的数据....
因为是连另一台机器,我现在又无法以管理员登录,所以无法直接删除重建用户,请问用SQL语句该如何删除一个用户下的所有表
还有试图,函数,自定义数据类型,总之是所有的数据. 展开
还有试图,函数,自定义数据类型,总之是所有的数据. 展开
3个回答
展开全部
你需要创建这些删除语句,通过oracle的数据字典找到该用户下的所有表、视图等对象,拼接成语句。如下
select 'drop table ' || table_name ||';'||chr(13)||chr(10) from user_tables; --delete tables
select 'drop view ' || view_name||';'||chr(13)||chr(10) from user_views; --delete views
select 'drop sequence ' || sequence_name||';'||chr(13)||chr(10) from user_sequences;--delete seqs
select 'drop function ' || object_name||';'||chr(13)||chr(10) from user_objects where object_type='FUNCTION';--delete functions
select 'drop procedure ' || object_name||';'||chr(13)||chr(10) from user_objects where object_type='PROCEDURE';--DELETE PROCEDURE
select 'drop package ' || object_name||';'||chr(13)||chr(10) from user_objects where object_type='PACKAGE';--delete pags
select 'drop table ' || table_name ||';'||chr(13)||chr(10) from user_tables; --delete tables
select 'drop view ' || view_name||';'||chr(13)||chr(10) from user_views; --delete views
select 'drop sequence ' || sequence_name||';'||chr(13)||chr(10) from user_sequences;--delete seqs
select 'drop function ' || object_name||';'||chr(13)||chr(10) from user_objects where object_type='FUNCTION';--delete functions
select 'drop procedure ' || object_name||';'||chr(13)||chr(10) from user_objects where object_type='PROCEDURE';--DELETE PROCEDURE
select 'drop package ' || object_name||';'||chr(13)||chr(10) from user_objects where object_type='PACKAGE';--delete pags
展开全部
在该用户下写一个存储过程(要保证该用户并不是以dba身份登录的,不然会把系统表都删掉哦)
create
or
replace
procedure
pro_droptable
is
cursor
cur
is
select
table_name
from
user_tables;
drop_sql
varchar2(1000);
begin
for
tbname
in
cur
loop
begin
drop_sql:='drop
table
'||tbname.table_name;
execute
immediate
drop_sql;
end;
end
loop;
end
pro_droptable;
然后执行就ok啦
执行语句:call
pro_droptable()
create
or
replace
procedure
pro_droptable
is
cursor
cur
is
select
table_name
from
user_tables;
drop_sql
varchar2(1000);
begin
for
tbname
in
cur
loop
begin
drop_sql:='drop
table
'||tbname.table_name;
execute
immediate
drop_sql;
end;
end
loop;
end
pro_droptable;
然后执行就ok啦
执行语句:call
pro_droptable()
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
因为ORACLE等中大型数据库一般不推荐采用批量删除,因为效率会很慢,还是逐行删除比较好。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询