ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2022-01-26 15:34:24  阅读:218  来源: 互联网

标签:tables 存在 删除 创建 视图 EMP table sysibm syscat


转至:https://blog.csdn.net/lzh3521/article/details/84405848?spm=1001.2101.3001.6650.2&utm_medium=distribute.pc_relevant.none-task-blog-2~default~CTRLIST~Rate-2.pc_relevant_aa&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2~default~CTRLIST~Rate-2.pc_relevant_aa&utm_relevant_index=5

 

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  表
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平坦软件园

标签:tables,存在,删除,创建,视图,EMP,table,sysibm,syscat
来源: https://www.cnblogs.com/my-first-blog-lgz/p/15846706.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有