我正在为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';
可是将DROP
与DROP
绑在一块儿的语法正在逃避我。 oracle
只是想发布一个完整的代码来建立一个表,若是已经存在使用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;
我更喜欢指定表和架构全部者。 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; /
可悲的是,若是存在则没有丢弃,或者若是不存在则不会建立
您能够编写一个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;
在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
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')