oracle创建表之前判断表是不是存在,如果存在则删除已有表

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle创建表之前判断表是不是存在,如果存在则删除已有表相关的知识,希望对你有一定的参考价值。

参考技术A SQL> create table test(a number);
  Table created
  SQL>
  SQL> declare
  2 v_count number;
  3 begin
  4 select count(1) into v_count from user_tables t where t.TABLE_NAME='TEST';5 if v_count>0 then
  6 execute immediate'drop table TEST';
  7 end if;
  8 execute immediate 'create table test(b number)';9 end;
  10 /
  PL/SQL procedure successfully completed
  SQL> select * from test;
  B
参考技术B 不用判断,直接先执行删除你要创建的表名,然后再执行创建语句;
很完美,为什么要判断呢?本回答被提问者采纳

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

这篇文章主要介绍了Oracle删除表、字段之前判断表、字段是否存在的相关资料,需要的朋友可以参考下

 

 

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

ORA-00942:表或视图不存在

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

1
2
3
4
5
6
7
8
9
10
11
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”:标识符无效

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

1
2
3
4
5
6
7
8
9
10
11
12
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删除表字段之前判断表字段是否存在

c#里面怎么判断数据库是不是存在

如果 Oracle 中不存在表,则创建一个表(使用 Java)

Sql Server 判断表是否存在方法

Oracle如何判断表存在,若存在则进行删除