oracle清空所有表

一.禁止所有的外键约束

SELECT 'ALTER TABLE ' || table_name || ' disable CONSTRAINT ' || constraint_name || ';' FROM user_constraints where CONSTRAINT_TYPE = 'R';

二、用delete或truncate删除所有表的内容

SELECT 'DELETE FROM '|| table_name || ';' FROM USER_TABLES ORDER BY TABLE_NAME;

SELECT 'TRUNCATE TABLE '|| table_name || ';' FROM USER_TABLES ORDER BY TABLE_NAME;

若表的数据有触发器相关联,只能用truncate语句,不过truncate语句不能回滚,所以使用时需注意

三、把已经禁止的外键打开

SELECT 'ALTER TABLE ' || table_name || ' enable CONSTRAINT ' || constraint_name || ';' FROM user_constraints where CONSTRAINT_TYPE = 'R';

 

posted @ 2020-12-01 15:46  玄澈  阅读(714)  评论(0编辑  收藏  举报