在Oracle中若刪除一個(gè)不存在的表,如 “DROP TABLE tableName”,則會(huì)提示:
ORA-00942:表或視圖不存在
若在程序中執(zhí)行該語句則會(huì)報(bào)異常,這就需要我們?cè)趧h除表前先判斷該表是否存在,若存在則刪除.
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中若刪除表中一個(gè)不存在的字段,如 “alter table test drop column xxx”,則會(huì)提示:
ORA-00904:”xxx”:標(biāo)識(shí)符無效
若在程序中執(zhí)行該語句則會(huì)報(bào)異常,這就需要我們?cè)趧h除字段前先判斷該字段是否存在,若存在則刪除.
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; 


















