Oracle中,如何删除一个用户下的所有表

因为是连另一台机器,我现在又无法以管理员登录,所以无法直接删除重建用户,请问用SQL语句该如何删除一个用户下的所有表还有试图,函数,自定义数据类型,总之是所有的数据.... 因为是连另一台机器,我现在又无法以管理员登录,所以无法直接删除重建用户,请问用SQL语句该如何删除一个用户下的所有表
还有试图,函数,自定义数据类型,总之是所有的数据.
展开
 我来答
netgr
推荐于2017-11-25 · TA获得超过251个赞
知道小有建树答主
回答量:277
采纳率:0%
帮助的人:331万
展开全部
你需要创建这些删除语句,通过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
郑成周亢凯
2019-05-31 · TA获得超过2.9万个赞
知道大有可为答主
回答量:1.1万
采纳率:26%
帮助的人:879万
展开全部
在该用户下写一个存储过程(要保证该用户并不是以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()
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
lzg5213
2008-01-21 · 超过25用户采纳过TA的回答
知道答主
回答量:81
采纳率:0%
帮助的人:51.3万
展开全部
因为ORACLE等中大型数据库一般不推荐采用批量删除,因为效率会很慢,还是逐行删除比较好。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式