-
여러 스키마들의 유저 정보 및 DB Link를 제외한 모든 정보 삭제DB/Oracle 2024. 11. 4. 16:51반응형
BEGIN -- 스키마 목록 FOR schema_name IN ( SELECT 'Schem1' AS schema_name FROM dual UNION ALL SELECT 'Schem2' FROM dual UNION ALL SELECT 'Schem3' FROM dual UNION ALL SELECT 'Schem4' FROM dual UNION ALL SELECT 'Schem5' FROM dual UNION ALL SELECT 'Schem6' FROM dual UNION ALL SELECT 'Schem7' FROM dual ) LOOP -- 1. 테이블 삭제 (CASCADE CONSTRAINTS 포함) FOR t IN (SELECT table_name FROM all_tables WHERE owner = schema_name.schema_name) LOOP EXECUTE IMMEDIATE 'DROP TABLE ' || schema_name.schema_name || '.' || t.table_name || ' CASCADE CONSTRAINTS'; END LOOP; -- 2. 독립적으로 생성된 인덱스 삭제 FOR idx IN (SELECT index_name FROM all_indexes WHERE owner = schema_name.schema_name AND table_name IS NULL) LOOP EXECUTE IMMEDIATE 'DROP INDEX ' || schema_name.schema_name || '.' || idx.index_name; END LOOP; -- 3. 프로시저, 함수, 패키지 삭제 FOR obj IN ( SELECT object_name, object_type FROM all_objects WHERE owner = schema_name.schema_name AND object_type IN ('PROCEDURE', 'FUNCTION', 'PACKAGE') ) LOOP EXECUTE IMMEDIATE 'DROP ' || obj.object_type || ' ' || schema_name.schema_name || '.' || obj.object_name; END LOOP; -- 4. 잡(JOB) 삭제 FOR job IN (SELECT job_name FROM all_scheduler_jobs WHERE owner = schema_name.schema_name) LOOP DBMS_SCHEDULER.drop_job(job_name => schema_name.schema_name || '.' || job.job_name, force => TRUE); END LOOP; -- 5. View 삭제 FOR v IN ( SELECT owner, view_name FROM all_views WHERE owner = schema_name.schema_name ) LOOP EXECUTE IMMEDIATE 'DROP VIEW ' || v.owner || '.' || v.view_name; END LOOP; -- 6. Synonym 삭제 FOR synonym_rec IN ( SELECT owner, synonym_name FROM all_synonyms WHERE owner = schema_name.schema_name ) LOOP EXECUTE IMMEDIATE 'DROP SYNONYM ' || synonym_rec.owner || '.' || synonym_rec.synonym_name; END LOOP; END LOOP; END; /
반응형'DB > Oracle' 카테고리의 다른 글
ORACLE - Scheduler JOB (0) 2025.01.06 Oracle DB - expdp / impdp (0) 2024.08.27 DB User별 - Session Timeout 설정 (0) 2024.07.17 RDS - SESSION KILL (0) 2024.06.11 Table Space 공간 확인 (0) 2024.01.25 댓글