mysql建表如果存在删除吗_创建表之前判断表是否存在,如果存在则删除已有表...

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

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

Sql代码    www.2cto.com

----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

ORACLE 数据库

但是在oracle中却没有。如果直接使用drop table那么如果表不存在会报错,导致后续语句无法运行。因此可以通过一个存储过来来进行判断。

主要是查询all_tables表的TABLE_NAME和OWNER,如果表存在,则执行execute immediate 'drop table TABLE_NAME';

Sql代码

--判断表是否存在,如果存在则删除

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));

现在使用DB2,网上找了很久也没个好方法,基本上用简单的sql语句来实现是不大可能的,能找到的方法都是自己写存储过程实现

删除表的如下:

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  表

sysibm.tables  表

syscat.views 视图

sysibm.views 视图

以上表和视图的系统视图在syscat和sysibm里都存在,个人水平不高,不知道是为什么,呵呵,从网上搜到的信息里摘一段出来如下:

数据库的视图里有sysibm.tables和syscat.tables,这两个有什么区别?很多资料上不是说sysibm模式的是基表吗,怎么在视图里也有sysibm模式,是干什么用的?

sysibm.tables的表里面的信息比syscat.tables的少,或者说IBM认为你想知道的信息在sysibm.tables里面已经都可以知道了,这个应该是给用户使用的。syscat.tables应该是给系统使用的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值