AI智能
改变未来

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

oracle创建表之前判断表是否存在,如果存在则删除已有表 在sqlserver中,有if exit()这样的语句,但是在oracle中却没有。如果直接使用drop table那么如果表不存在会报错,导致后续语句无法运行。因此可以通过一个存储过来来进行判断。 主要是查询all_tables表的TABLE_NAME和OWNER,如果表存在,则执行execute immediate \’drop table TABLE_NAME\’; 复制代码

--判断表是否存在,如果存在则删除declarenum   number;beginselect count(1) into num from all_tables where TABLE_NAME = \'EMP\' and OWNER=\'SCOTT\';if   num=1   thenexecute immediate \'drop table EMP\';end   if;end;/--创建表CREATE TABLE EMP(EMPNO NUMBER(4) NOT NULL,ENAME VARCHAR2(10),JOB VARCHAR2(9),MGR NUMBER(4),HIREDATE DATE,SAL NUMBER(7, 2),COMM NUMBER(7, 2),DEPTNO NUMBER(2));

复制代码 可以将上述存储过程加载到每一个create table前面。

转载于:Oracle/3522527

赞(0) 打赏
未经允许不得转载:爱站程序员基地 » oracle创建表之前判断表是否存在,如果存在则删除已有表