Oracle删除表、字段之前判断表、字段是否存在
程序员文章站
2022-07-01 19:20:40
在oracle中若删除一个不存在的表,如 “drop table tablename”,则会提示:
ora-00942:表或视图不存在
若在程序中执行该语句则会报异常,...
在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;
推荐阅读
-
oracle中查看一张表是否有主键,主键在哪个字段上
-
Oracle创建表、删除表、修改表(添加字段、修改字段、删除字段)语句总结
-
oracle自定义存储过程:删除表(无论表是否存在)和检测表是否存在
-
删除表中多余的重复记录,重复记录是根据单个字段(Id)来判断,只留有rowid最小的记录
-
Oracle判断表、列、主键是否存在的方法
-
Oracle删除表前判断表名是否存在若存在则删除
-
Oracle查询表中字段里数据是否有重复的方法
-
oracle删除表字段和oracle表增加字段
-
简单实用:Oracle/Sqlserver/Sqlite 判断某张表是否存在的SQL语句
-
简单实用:Oracle/Sqlserver/Sqlite 判断某张表是否存在的SQL语句