度量快速开发平台-专业、快速的软件定制快开平台

标题: Oracle删除表/字段之前判断表/字段是否存在 [打印本页]

作者: 张兴康    时间: 2020-3-9 13:14
标题: Oracle删除表/字段之前判断表/字段是否存在
在Oracle中若删除一个不存在的表,如 “DROP TABLE tableName”,则会提示:
ORA-00942:表或视图不存在
若在程序中执行该语句则会报异常,这就需要我们在删除表前先判断该表是否存在,若存在则删除.
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;

在Oracle中若删除表中一个不存在的字段,如 “alter table test drop column xxx”,则会提示:
ORA-00904:”xxx”:标识符无效
若在程序中执行该语句则会报异常,这就需要我们在删除字段前先判断该字段是否存在,若存在则删除.
DECLARE
num NUMBER;
BEGIN
SELECT COUNT(1)
INTO num
from cols
where table_name = upper('tableName')
and column_name = upper('columnName');
IF num > 0 THEN
execute immediate 'alter table tableName drop column columnName';
END IF;
END;


作者: 陈晓龙    时间: 2020-3-9 14:12

作者: 陈晓龙    时间: 2020-3-9 14:13

作者: 张兴康    时间: 2020-3-10 13:31
陈晓龙 发表于 2016-10-9 14:13


作者: 陈晓龙    时间: 2020-3-10 15:53
张兴康 发表于 2016-10-10 13:31


作者: 张兴康    时间: 2020-3-11 14:14





欢迎光临 度量快速开发平台-专业、快速的软件定制快开平台 (http://p.delit.cn/) Powered by Discuz! X3.2