oracle创建表之前判断表是否存在,如果存在则删除已有表
在sqlserver中,有if exit()这样的语句,但是在oracle中却没有。如果直接使⽤drop table那么如果表不存在会报错,导致后续语句⽆法运⾏。因此可以通过⼀个存储过来来进⾏判断。
主要是查询all_tables表的TABLE_NAME和OWNER,如果表存在,则执⾏execute immediate 'drop table TABLE_NAME';
--判断表是否存在,如果存在则删除
declare
num  number;
begin
drop删除表
select count(1) into num from all_tables where TABLE_NAME ='EMP'and OWNER='SCOTT';
if  num=1then
execute 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前⾯。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。