重庆

点击搜索

发布

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

区域:
重庆 > 南岸 > 南坪
类别:
软件工程师培训
地址:
重庆市南岸区五公里工商大学(金豫时尚购物中心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;
 
查看更多重庆电脑/网络信息

免责声明:此信息系发布者(UID:165414)自行发布,本站是服务平台,仅提供信息存储空间服务,该信息内容的真实性及合法性由该发布者完全负责。

© lieju.com 联系我们