创建表之前判断表是否存在,如果存在则删除已有表
1.sqlserver数据库
在sqlserver中,创建表之前判断表是否存在,如果存在则删除已有表
----SQL-Server
if exists (select 1
from sysobjects
where id = object_id('EMP')
and type = 'U')
drop table S_Evaluate
go
--CREATE Table: EMP
create table EMP(
Id numeric identity, -- 评估ID
Conclusion text null --结论
constraint PK_S_EMP primary key nonclustered(Id)
)
go
2.ORACLE 数据库
但是在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));
3.DB2
现在使⽤DB2,⽹上了很久也没个好⽅法,基本上⽤简单的sql语句来实现是不⼤可能的,能到的⽅法都是⾃⼰写存储过程实现
删除表的如下:
CREATE PROCEDURE ExistsTest(IN TableName varchar(50),OUT iReturn int)
LANGUAGE SQL
P1: BEGIN
DECLARE stmt VARCHAR(200);
IF EXISTS (select * from sysibm.systables where TID <> 0 and name = TableName ) THEN
set stmt ='drop table '|| TableName;
PREPARE s1 FROM stmt;
EXECUTE s1;
set iReturn =0;
else
set iReturn =-1;
END IF;
END P1@
END P1后⾯的@根据所⽤编辑⼯具的不同,默认的结束也不⼀样。测试了⼀下QUEST CENTRAL FOR DB2,默认是分号,如果想⽤@⾃⼰修改⼯具的配置吧
由于DB2不像sqlserver那样把所有对象组织到⼀个sysobjects⾥,所以想要实现不同的功能就需要修改这个存储过程,
如:
syscat.procedures 存储过程
syscat.tables 表
oracle数据库怎么查询表sysibm.tables 表
syscat.views 视图
sysibm.views 视图
以上表和视图的系统视图在syscat和sysibm⾥都存在,个⼈⽔平不⾼,不知道是为什么,呵呵,从⽹上搜到的信息⾥摘⼀段出来如下:数据库的视图⾥有sysibm.tables和syscat.tables,这两个有什么区别?很多资料上不是说sysibm模式的是基表吗,怎么在视图⾥也有sysibm模式,是⼲什么⽤的?gmx平坦软件园
sysibm.tables的表⾥⾯的信息⽐syscat.tables的少,或者说IBM认为你想知道的信息在sysibm.tables⾥⾯已经都可以知道了,这个应该是给⽤户使⽤的。syscat.tables应该是给系统使⽤的。gmx平坦软件园
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论