zoukankan      html  css  js  c++  java
  • 创建表之前判断表是否存在,如果存在则删除已有表

    创建表之前判断表是否存在,如果存在则删除已有表
     
    在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应该是给系统使用的。
  • 相关阅读:
    决策树分类
    集群服务器 获取COOKIE错误
    React 自写Loading
    HTB-靶机-Unattended
    HTB-靶机-LaCasaDePapel
    HTB-靶机-FriendZone
    HTB-靶机-CTF
    HTB-靶机-FluJab
    HTB-靶机-Help
    HTB-靶机-Chaos
  • 原文地址:https://www.cnblogs.com/dullbaby/p/3173499.html
Copyright © 2011-2022 走看看