ORACLE中判断表是否存在再删除表避免报错与MySql和SqlServer的不同

不同数据库中drop a table if it exists的不同:

In MySQL it is pretty easy to drop a table if it exists already. In Oracle and Microsoft's SQL Server it is a little more complicated. Today I want to present you the solutions for these two DBMS'.

MySQL:

sql 复制代码
DROP TABLE IF EXISTS [table_name]

Oracle:

sql 复制代码
BEGIN
    EXECUTE IMMEDIATE 'DROP TABLE [table_name]';
    EXCEPTION WHEN OTHERS THEN NULL;
END;

SQL Server:

sql 复制代码
IF EXISTS (
    SELECT  TABLE_NAME FROM INFORMATION_SCHEMA.TABLES
    WHERE   TABLE_NAME = '[table_name]')
DROP TABLE  [table_name]

ORACLE中先判断表是否存在再新建表一例:

sql 复制代码
declare
 v_exists number;
begin
	   --1、任务类型 TASK_TYPE_CD 建表...
    select count(*) into v_exists from user_tables where table_name = 'EDW_T99_TASK_TYPE_CD';
    if v_exists > 0 then
    execute immediate 'drop table EDW_T99_TASK_TYPE_CD';
    end if;
    execute immediate '
    create table EDW_T99_TASK_TYPE_CD
    (
      CODE_CD   VARCHAR2(20) PRIMARY KEY,
      CODE_DESC VARCHAR2(100)
    )';
    execute immediate 'comment on table EDW_T99_TASK_TYPE_CD is ''任务类型''';
    execute immediate 'comment on column EDW_T99_TASK_TYPE_CD.CODE_CD is ''代码''';
    execute immediate 'comment on column EDW_T99_TASK_TYPE_CD.CODE_DESC is ''代码描述''';

	   --2、买入产品代码 BUY_TYPE_CD 建表...
    select count(*) into v_exists from user_tables where table_name = 'EDW_T99_BUY_TYPE_CD';
    if v_exists > 0 then
    execute immediate 'drop table EDW_T99_BUY_TYPE_CD';
    end if;
    execute immediate '
    create table EDW_T99_BUY_TYPE_CD
    (
      CODE_CD   VARCHAR2(20) PRIMARY KEY,
      CODE_DESC VARCHAR2(100)
    )';
    execute immediate 'comment on table EDW_T99_BUY_TYPE_CD is ''买入产品代码''';
    execute immediate 'comment on column EDW_T99_BUY_TYPE_CD.CODE_CD is ''代码''';
    execute immediate 'comment on column EDW_T99_BUY_TYPE_CD.CODE_DESC is ''代码描述''';
	   
end;
/

此例用在数据仓库项目的建T99代码表脚本方案上;此脚本在方案中用Perl根据Excel生成。

相关推荐
chen_note8 分钟前
LAMP及其环境的部署搭建
linux·运维·mysql·php·apache·lamp·phpmyadmin
瓶子xf17 分钟前
基于mysql云数据库对比PowerBI vs QuickBI vs FineBI更换数据源的可行性
mysql·powerbi·quickbi
曾几何时`17 分钟前
MySQL(配置)——MariaDB使用
数据库·mysql
努力学习java的哈吉米大王20 分钟前
MySQL——MVCC
数据库·mysql
数据要素X34 分钟前
【数据架构10】数字政府架构篇
大数据·运维·数据库·人工智能·架构
lixzest1 小时前
Redis实现数据传输简介
数据库·redis·缓存
搬砖的小熊猫1 小时前
MySQL常见面试题
数据库·mysql
weixin_419658312 小时前
MySQL的JDBC编程
数据库·mysql
JavaLearnerZGQ2 小时前
Docker部署Nacos
数据库·docker·容器
何传令2 小时前
SQL排查、分析海量数据以及锁机制
数据库·sql·mysql