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