Oracle删除表、字段之前判断表、字段是否存在
在Oracle中若删除一个不存在的表,如“DROPTABLEtableName”,则会提示:
ORA-00942:表或视图不存在
若在程序中执行该语句则会报异常,这就需要我们在删除表前先判断该表是否存在,若存在则删除.
DECLARE
numNUMBER;
BEGIN
SELECTCOUNT(1)
INTOnum
FROMUSER_TABLES
WHERETABLE_NAME=UPPER('tableName');
IFnum>0THEN
EXECUTEIMMEDIATE'DROPTABLEtableName';
ENDIF;
END;
在Oracle中若删除表中一个不存在的字段,如“altertabletestdropcolumnxxx”,则会提示:
ORA-00904:”xxx”:标识符无效
若在程序中执行该语句则会报异常,这就需要我们在删除字段前先判断该字段是否存在,若存在则删除.
DECLARE
numNUMBER;
BEGIN
SELECTCOUNT(1)
INTOnum
fromcols
wheretable_name=upper('tableName')
andcolumn_name=upper('columnName');
IFnum>0THEN
executeimmediate'altertabletableNamedropcolumncolumnName';
ENDIF;
END;