重庆列举网 > 教育培训 > 电脑/网络 > Oracle重庆江田学院 删除用户下的所有的表的方
重庆
[切换城市]

Oracle重庆江田学院 删除用户下的所有的表的方

更新时间:2014-12-24 15:37:35 浏览次数:209次
区域: 重庆 > 南岸 > 南坪
类别:软件工程师培训
地址:重庆市南岸区五公里工商大学(金豫时尚购物中心4F)


删除用户下的所有的表的方法
 
直接了当的方法_Oracle重庆江田学院:
 
先以sys as sysdba 登陆Oracle
 
>sql shutdown
 
>sql startup
 
drop user username cascade
 
创建新用户
 
1、
 
select   'Drop   table   '||table_name||';'
 
from   all_tables
 
where   owner='要删除的用户名(注意要大写)';
 
2、
 
删除所有表
 
以用户test为例
 
for example:
 
declare
 
cursor cur1 is select table_name from dba_tables where owner='TEST'; Oracle重庆江田学院
 
begin
 
for cur2 in cur1 loop
 
execute immediate 'drop table test.'||cur2.table_name;
 
end loop;
 
end;
 
3、这个删除当前用户的所有对象(表、视图、触发器、存储过程、函数)
 
没试过
 
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; Oracle重庆江田学院
 
END LOOP;
 
END;
 
重庆电脑/网络相关信息
2小时前
注册时间:2014年11月17日
UID:165414
---------- 认证信息 ----------

查看用户主页