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

创建表之前判断表是否存在,如果存在则删除已有表
 
在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应该是给系统使用的。
posted on 2013-07-05 12:50  笨小孩做开发 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/dullbaby/p/3173499.html

### 回答1: 达梦数据库中,在创建表时如果已经存在,可以使用"if not exists"语句来判断是否存在。具体的语法如下: ```sql create table if not exists 名( 列名1 数据类型1, 列名2 数据类型2, ... ); ``` 在这个语句中,如果名已经存在,则不会执行创建表的操作,而是直接跳过该语句继续执行后面的语句。这样可以避免因为重复创建而导致的错误。 下面是一个示例: ```sql create table if not exists student( id int, name varchar(50), age int ); ``` 如果student已经存在,则不会执行创建表的操作。如果不存在,则会创建一个名为student的,该包含id、name和age三个列。 使用"if not exists"语句可以保证在创建表时不会因为存在而报错,提高了创建表的稳定性和可靠性。 ### 回答2: 达梦数据库创建表时,如果已经存在,可以使用SQL语句来处理。一种常用的方法是使用"IF NOT EXISTS"关键字来判断是否存在,如果不存在创建表。 例如,使用以下SQL语句创建表: ``` CREATE TABLE IF NOT EXISTS mytable ( id INT PRIMARY KEY, name VARCHAR(50) ); ``` 如果名为mytable的已经存在,则这条SQL语句不会执行任何操作。如果存在,则会创建一个名为mytable的,并定义id和name两个字段。 此外,还可以使用"DROP TABLE IF EXISTS"语句,先判断是否存在,如果存在删除,然后再创建新的。 ``` DROP TABLE IF EXISTS mytable; CREATE TABLE mytable ( id INT PRIMARY KEY, name VARCHAR(50) ); ``` 这种方法可以用来先删除并创建新,确保的结构与定义完全一致。 总而言之,达梦数据库创建表时,如果已经存在,可以使用IF语句来判断存在与否,并采取相应的操作,以确保的创建与定义。 ### 回答3: 达梦数据库创建表时,如果已经存在,可以使用SQL语句进行的处理。一般情况下,有以下几种操作方式: 1. 忽略已存在:使用`CREATE TABLE IF NOT EXISTS`语句可以创建表,如果已经存在,则忽略该操作。这样就不会对已经存在进行任何修改,保持原有结构的完整性。 2. 删除存在:可以使用`DROP TABLE IF EXISTS`语句删除存在,然后再创建新的。这样会先删除原有的,然后重新创建一个新的结构。 3. 修改已存在:使用`ALTER TABLE`语句可以对已存在进行修改。可以添加、删除、修改列的定义,也可以增加、删除、修改的约束,如主键、外键等。 需要注意的是,对于已存在进行删除或修改操作时,可能会导致数据的丢失或结构的改变,因此在执行操作前一定要谨慎进行,并备份好相关数据。 达梦数据库创建表时如果存在,通过使用上述的相关SQL语句,可以灵活地处理已存在,保证数据库的完整性和数据的有效性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值