首页 > 数据库 > Oracle > 正文

Oracle删除表、字段之前判断表、字段是否存在

2020-07-26 14:12:57
字体:
来源:转载
供稿:网友

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

ORA-00942:表或视图不存在

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

DECLAREnum NUMBER;BEGINSELECT COUNT(1)INTO numFROM USER_TABLESWHERE TABLE_NAME = UPPER('tableName');IF num > 0 THENEXECUTE IMMEDIATE 'DROP TABLE tableName';END IF;END;

在Oracle中若删除表中一个不存在的字段,如 “alter table test drop column xxx”,则会提示:

ORA-00904:”xxx”:标识符无效

若在程序中执行该语句则会报异常,这就需要我们在删除字段前先判断该字段是否存在,若存在则删除.

DECLAREnum NUMBER;BEGINSELECT COUNT(1)INTO numfrom colswhere table_name = upper('tableName')and column_name = upper('columnName');IF num > 0 THENexecute immediate 'alter table tableName drop column columnName';END IF;END;

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表