Heim  >  Artikel  >  Datenbank  >  Oracle 删除表前判断表名是否存在

Oracle 删除表前判断表名是否存在

WBOY
WBOYOriginal
2016-06-07 17:33:251578Durchsuche

在Oracle中若删除一个不存在的表,如 DROP TABLE notExistTable,则会提示:ORA-00942:表或视图不存在,若使用程序执行该语句则会报

在Oracle中若删除一个不存在的表,如 "DROP TABLE notExistTable",则会提示:

ORA-00942:表或视图不存在,

若使用程序执行该语句则会报异常,这就需要我们再删除表前判断该表是否存在,若存在则删除.

下面是不使用存储过程实现删除表的SQL:

DECLARE num NUMBER;
BEGIN
SELECT COUNT(1) INTO num FROM USER_TABLES WHERE TABLE_NAME = UPPER('tableName') ;
IF num > 0 THEN
  EXECUTE IMMEDIATE 'DROP TABLE tableName' ;
END IF;
END;

相关阅读:

删除表空间报错ORA-600(ktssdrp1)错误

Oracle 删除表名命名不合法的表

Linux下Oracle删除表空间引发错误的解决方法

Oracle 误删除表数据恢复

Oracle利用rowid删除表中重复记录

Oracle无法删除表

linux

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Vorheriger Artikel:Oracle 10g 安装图解教程Nächster Artikel:Oracle的Lpad函数