Oracle에서 모든 사용자 테이블을 삭제하려면 어떻게해야합니까?
제약 조건에 문제가 있습니다. 모두 비활성화하면 여전히 불가능합니다.
Oracle에서 모든 사용자 테이블을 삭제하려면 어떻게해야합니까?
제약 조건에 문제가 있습니다. 모두 비활성화하면 여전히 불가능합니다.
답변:
BEGIN
FOR cur_rec IN (SELECT object_name, object_type
FROM user_objects
WHERE object_type IN
('TABLE',
'VIEW',
'MATERIALIZED VIEW',
'PACKAGE',
'PROCEDURE',
'FUNCTION',
'SEQUENCE',
'SYNONYM',
'PACKAGE BODY'
))
LOOP
BEGIN
IF cur_rec.object_type = 'TABLE'
THEN
EXECUTE IMMEDIATE 'DROP '
|| cur_rec.object_type
|| ' "'
|| cur_rec.object_name
|| '" CASCADE CONSTRAINTS';
ELSE
EXECUTE IMMEDIATE 'DROP '
|| cur_rec.object_type
|| ' "'
|| cur_rec.object_name
|| '"';
END IF;
EXCEPTION
WHEN OTHERS
THEN
DBMS_OUTPUT.put_line ('FAILED: DROP '
|| cur_rec.object_type
|| ' "'
|| cur_rec.object_name
|| '"'
);
END;
END LOOP;
FOR cur_rec IN (SELECT *
FROM all_synonyms
WHERE table_owner IN (SELECT USER FROM dual))
LOOP
BEGIN
EXECUTE IMMEDIATE 'DROP PUBLIC SYNONYM ' || cur_rec.synonym_name;
END;
END LOOP;
END;
/
이 작업을 수행하는 정말 간단한 방법을 원한다면 여기에 과거에 사용한 스크립트가 있습니다.
select 'drop table '||table_name||' cascade constraints;' from user_tables;
스키마의 모든 테이블에 대해 일련의 삭제 명령이 인쇄됩니다. 이 쿼리 결과를 스풀하고 실행하십시오.
출처 : https://forums.oracle.com/forums/thread.jspa?threadID=614090
마찬가지로 테이블 이상을 지우려면 필요에 따라 다음을 편집 할 수 있습니다.
select 'drop '||object_type||' '|| object_name || ';' from user_objects where object_type in ('VIEW','PACKAGE','SEQUENCE', 'PROCEDURE', 'FUNCTION', 'INDEX')
나를 위해 일한 또 다른 대답은 ( http://snipt.net/Fotinakis/drop-all-tables-and-constraints-within-an-oracle-schema/에 대한 신용 )
BEGIN
FOR c IN (SELECT table_name FROM user_tables) LOOP
EXECUTE IMMEDIATE ('DROP TABLE "' || c.table_name || '" CASCADE CONSTRAINTS');
END LOOP;
FOR s IN (SELECT sequence_name FROM user_sequences) LOOP
EXECUTE IMMEDIATE ('DROP SEQUENCE ' || s.sequence_name);
END LOOP;
END;
이 기능은 실행 한 직후에 작동 합니다. 어딘가에 붙여 넣을 필요가있는 스크립트를 생성 하지 않습니다 (여기의 다른 답변처럼). DB에서 직접 실행됩니다.
'DROP TABLE "' || c.table_name || '" CASCADE CONSTRAINTS'
. 테이블 이름이 소문자 인 경우에 필요합니다.
PURGE
끝에 추가하겠습니다 DROP
.
가장 간단한 방법은 캐스케이드 명령으로 객체를 소유 한 사용자를 삭제하는 것입니다.
DROP USER username CASCADE
USER
는 a 와 분리됩니다 DATABASE
. DROP USER username CASCADE
나를 위해 일했다. 그러나 MySQL에서해야 할 일은 DROP DATABASE
새로운 것을 만드는 것입니다
가장 쉬운 방법은 테이블 스페이스를 삭제 한 다음 테이블 스페이스를 다시 빌드하는 것입니다. 그러나 나는 그렇게 할 필요가 없습니다. 이것은 내 GUI의 결과 집합에 복사 / 붙여 넣기만한다는 점을 제외하고 Henry의 것과 유사합니다.
SELECT
'DROP'
,object_type
,object_name
,CASE(object_type)
WHEN 'TABLE' THEN 'CASCADE CONSTRAINTS;'
ELSE ';'
END
FROM user_objects
WHERE
object_type IN ('TABLE','VIEW','PACKAGE','PROCEDURE','FUNCTION','SEQUENCE')
SELECT 'DROP TABLE "' || TABLE_NAME || '" CASCADE CONSTRAINTS;'
FROM user_tables;
user_tables
SELECT 절이 스크립트를 실행할 수있는 모든 테이블에 대해 DROP 문을 생성하는 사용자의 모든 테이블을 포함하는 시스템 테이블입니다.
오라클의 모든 객체를 제거하려면
1) 동적
DECLARE
CURSOR IX IS
SELECT * FROM ALL_OBJECTS WHERE OBJECT_TYPE ='TABLE'
AND OWNER='SCHEMA_NAME';
CURSOR IY IS
SELECT * FROM ALL_OBJECTS WHERE OBJECT_TYPE
IN ('SEQUENCE',
'PROCEDURE',
'PACKAGE',
'FUNCTION',
'VIEW') AND OWNER='SCHEMA_NAME';
CURSOR IZ IS
SELECT * FROM ALL_OBJECTS WHERE OBJECT_TYPE IN ('TYPE') AND OWNER='SCHEMA_NAME';
BEGIN
FOR X IN IX LOOP
EXECUTE IMMEDIATE('DROP '||X.OBJECT_TYPE||' SCHEMA_NAME.'||X.OBJECT_NAME|| ' CASCADE CONSTRAINT');
END LOOP;
FOR Y IN IY LOOP
EXECUTE IMMEDIATE('DROP '||Y.OBJECT_TYPE||' SCHEMA_NAME.'||Y.OBJECT_NAME);
END LOOP;
FOR Z IN IZ LOOP
EXECUTE IMMEDIATE('DROP '||Z.OBJECT_TYPE||' SCHEMA_NAME.'||Z.OBJECT_NAME||' FORCE ');
END LOOP;
END;
/
2) 정적
SELECT 'DROP TABLE "' || TABLE_NAME || '" CASCADE CONSTRAINTS;' FROM user_tables
union ALL
select 'drop '||object_type||' '|| object_name || ';' from user_objects
where object_type in ('VIEW','PACKAGE','SEQUENCE', 'PROCEDURE', 'FUNCTION')
union ALL
SELECT 'drop '
||object_type
||' '
|| object_name
|| ' force;'
FROM user_objects
WHERE object_type IN ('TYPE');