在Oracle中若刪除一個不存在的表,如 “DROP TABLE tableName”,則會提示:
ORA-00942:表或視圖不存在
若在程序中執(zhí)行該語句則會報異常,這就需要我們在刪除表前先判斷該表是否存在,若存在則刪除.
DECLAREnum NUMBER;BEGINSELECT COUNT(1)INTO numFROM USER_TABLESWHERE TABLE_NAME = UPPER('tableName');IF num > 0 THENEXECUTE IMMEDIATE 'DROP TABLE tableName';END IF;END;
在Oracle中若刪除表中一個不存在的字段,如 “alter table test drop column xxx”,則會提示:
ORA-00904:”xxx”:標(biāo)識符無效
若在程序中執(zhí)行該語句則會報異常,這就需要我們在刪除字段前先判斷該字段是否存在,若存在則刪除.
DECLAREnum NUMBER;BEGINSELECT COUNT(1)INTO numfrom colswhere table_name = upper('tableName')and column_name = upper('columnName');IF num > 0 THENexecute immediate 'alter table tableName drop column columnName';END IF;END;