Oracle:若是表存在

我正在为Oracle数据库编写一些迁移脚本,而且但愿Oracle有相似MySQL的IF EXISTS结构。 sql

具体来讲,每当我想在MySQL中删除表时,我都会这样作 数据库

DROP TABLE IF EXISTS `table_name`;

这样,若是表不存在, DROP不会产生错误,脚本能够继续。 session

Oracle是否有相似的机制? 我意识到我可使用如下查询来检查表是否存在 架构

SELECT * FROM dba_tables where table_name = 'table_name';

可是将DROPDROP绑在一块儿的语法正在逃避我。 oracle


#1楼

只是想发布一个完整的代码来建立一个表,若是已经存在使用Jeffrey的代码就放弃它(对他而言,不是我!)。 spa

BEGIN
    BEGIN
         EXECUTE IMMEDIATE 'DROP TABLE tablename';
    EXCEPTION
         WHEN OTHERS THEN
                IF SQLCODE != -942 THEN
                     RAISE;
                END IF;
    END;

    EXECUTE IMMEDIATE 'CREATE TABLE tablename AS SELECT * FROM sourcetable WHERE 1=0';

END;

#2楼

我更喜欢指定表和架构全部者。 code

注意区分大小写。 (参见下面的“上部”条款)。 server

我扔了几个不一样的对象,以代表能够在TABLEs以外的地方使用。 htm

............. 对象

declare
   v_counter int;
begin
 select count(*) into v_counter from dba_users where upper(username)=upper('UserSchema01');
   if v_counter > 0 then
      execute immediate 'DROP USER UserSchema01 CASCADE';
   end if; 
end;
/



CREATE USER UserSchema01 IDENTIFIED BY pa$$word
  DEFAULT TABLESPACE users
  TEMPORARY TABLESPACE temp
  QUOTA UNLIMITED ON users;

grant create session to UserSchema01;

和一个TABLE示例:

declare
   v_counter int;
begin
 select count(*) into v_counter from all_tables where upper(TABLE_NAME)=upper('ORDERS') and upper(OWNER)=upper('UserSchema01');
   if v_counter > 0 then
      execute immediate 'DROP TABLE UserSchema01.ORDERS';
   end if; 
end;
/

#3楼

可悲的是,若是存在则没有丢弃,或者若是不存在则不会建立

您能够编写一个plsql脚原本包含逻辑。

http://download.oracle.com/docs/cd/B12037_01/server.101/b10759/statements_9003.htm

我对Oracle语法不太了解,但我认为@ Erich的脚本会是这样的。

declare 
cant integer
begin
select into cant count(*) from dba_tables where table_name='Table_name';
if count>0 then
BEGIN
    DROP TABLE tableName;
END IF;
END;

#4楼

在oracle中没有'DROP TABLE IF EXISTS',你必须作select语句。

试试这个(我没有使用oracle语法,因此若是个人变量是ify,请原谅我):

declare @count int
select @count=count(*) from all_tables where table_name='Table_name';
if @count>0
BEGIN
    DROP TABLE tableName;
END

#5楼

declare
   c int;
begin
   select count(*) into c from user_tables where table_name = upper('table_name');
   if c = 1 then
      execute immediate 'drop table table_name';
   end if;
end;

这是用于检查当前模式中的表是否存在。 要检查给定表是否已存在于不一样的模式中,您必须使用all_tables而不是user_tables并添加条件all_tables.owner = upper('schema_name')

相关文章
相关标签/搜索