在Oracle中若刪除一個(gè)不存在的表,如 “DROP TABLE tableName”,則會(huì)提示:
ORA-00942:表或視圖不存在
若在程序中執(zhí)行該語句則會(huì)報(bào)異常,這就需要我們在刪除表前先判斷該表是否存在,若存在則刪除.
DECLARE
num NUMBER;
BEGIN
SELECT COUNT(1)
INTO num
FROM USER_TABLES
WHERE TABLE_NAME = UPPER('tableName');
IF num > 0 THEN
EXECUTE IMMEDIATE 'DROP TABLE tableName';
END IF;
END;
在Oracle中若刪除表中一個(gè)不存在的字段,如 “alter table test drop column xxx”,則會(huì)提示:
ORA-00904:”xxx”:標(biāo)識符無效
若在程序中執(zhí)行該語句則會(huì)報(bào)異常,這就需要我們在刪除字段前先判斷該字段是否存在,若存在則刪除.
DECLARE
num NUMBER;
BEGIN
SELECT COUNT(1)
INTO num
from cols
where table_name = upper('tableName')
and column_name = upper('columnName');
IF num > 0 THEN
execute immediate 'alter table tableName drop column columnName';
END IF;
END;
您可能感興趣的文章:- 使用SQL語句查詢MySQL,SQLServer,Oracle所有數(shù)據(jù)庫名和表名,字段名
- Oracle數(shù)據(jù)庫表中字段順序的修改方法
- Oracle表字段的增刪改、表的重命名及主鍵的增刪改
- oracle獲取當(dāng)前用戶表、字段等詳細(xì)信息SQL
- oracle刪除表字段和oracle表增加字段
- 在oracle 數(shù)據(jù)庫查詢的select 查詢字段中關(guān)聯(lián)其他表的方法
- Oracle表字段有Oracle關(guān)鍵字出現(xiàn)異常解決方案