Oracle, Script para criar uma funcao para Dropar todos Objetos de um Schema especifico

julho 22, 2010

— CUIDADO QUE ELE DROPA!!!!!!! EXECUTAR NO SCHEMA ONDE DESEJA DELETAR OS OBJETOS.

create or replace
FUNCTION                DROP_ALL_SCHEMA_OBJECTS RETURN NUMBER AS
PRAGMA AUTONOMOUS_TRANSACTION;
cursor c_get_objects is
select object_type,'”‘||object_name||'”‘||decode(object_type,’TABLE’ ,’ cascade constraints’,null) obj_name
from user_objects
where object_type in (‘TABLE’,’VIEW’,’PACKAGE’,’SEQUENCE’,’SYNONYM’, ‘MATERIALIZED VIEW’)
order by object_type;
cursor c_get_objects_type is
select object_type, ‘”‘||object_name||'”‘ obj_name
from user_objects
where object_type in (‘TYPE’);
BEGIN
begin
for object_rec in c_get_objects loop
execute immediate (‘drop ‘||object_rec.object_type||’ ‘ ||object_rec.obj_name);
end loop;
for object_rec in c_get_objects_type loop
begin
execute immediate (‘drop ‘||object_rec.object_type||’ ‘ ||object_rec.obj_name);
end;
end loop;
end;
RETURN 0;
END DROP_ALL_SCHEMA_OBJECTS;

Em seguida, executar o seguinte comando parada executar a funcao:
select drop_all_schema_objects from dual;

Obs: Por uma questão de enconding, deverá ser trocado todos os pickles por aspas simples antes de executar o comando acima .


Anúncios

Deixe um comentário

Preencha os seus dados abaixo ou clique em um ícone para log in:

Logotipo do WordPress.com

Você está comentando utilizando sua conta WordPress.com. Sair /  Alterar )

Foto do Google

Você está comentando utilizando sua conta Google. Sair /  Alterar )

Imagem do Twitter

Você está comentando utilizando sua conta Twitter. Sair /  Alterar )

Foto do Facebook

Você está comentando utilizando sua conta Facebook. Sair /  Alterar )

Conectando a %s

%d blogueiros gostam disto: