Oracle判斷表、列、主鍵是否存在的方法
在編寫程序時(shí),數(shù)據(jù)庫結(jié)構(gòu)會經(jīng)常變化,所以經(jīng)常需要編寫一些數(shù)據(jù)庫腳本,編寫完成后需發(fā)往現(xiàn)場執(zhí)行,如果已經(jīng)存在或者重復(fù)執(zhí)行,有些腳本會報(bào)錯(cuò),所以需要判斷其是否存在,現(xiàn)在我就把經(jīng)常用到的一些判斷方法和大家分享下:
一。判斷Oracle表是否存在的方法
declare tableExistedCount number; --聲明變量存儲要查詢的表是否存在
begin
select count(1) into tableExistedCount from user_tables t where t.table_name = upper('Test'); --從系統(tǒng)表中查詢當(dāng)表是否存在
if tableExistedCount = 0 then --如果不存在,使用快速執(zhí)行語句創(chuàng)建新表
execute immediate
'create table Test --創(chuàng)建測試表
(ID number not null,Name = varchar2(20) not null)';
end if;
end;
二。判斷Oracle表中的列是否存在的方法
declare columnExistedCount number; --聲明變量存儲要查詢的表中的列是否存在
begin
--從系統(tǒng)表中查詢表中的列是否存在
select count(1) into columnExistedCount from user_tab_columns t where t.table_name = upper('Test') and t.column_name = upper('Age');
--如果不存在,使用快速執(zhí)行語句添加Age列
if columnExistedCount = 0 then
execute immediate
'alter table Test add age number not null';
end if;
end;
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;
三。判斷Oracle表是否存在主鍵的方法
declare primaryKeyExistedCount number; --聲明變量存儲要查詢的表中的列是否存在
begin
--從系統(tǒng)表中查詢表是否存在主鍵(因一個(gè)表只可能有一個(gè)主鍵,所以只需判斷約束類型即可)
select count(1) into primaryKeyExistedCount from user_constraints t where t.table_name = upper('Test') and t.constraint_type = 'P';
--如果不存在,使用快速執(zhí)行語句添加主鍵約束
if primaryKeyExistedCount = 0 then
execute immediate
'alter table Test add constraint PK_Test_ID primary key(id)';
end if;
end;
四。判斷Oracle表是否存在外鍵的方法
declare foreignKeyExistedCount number; --聲明變量存儲要查詢的表中的列是否存在
begin
--從系統(tǒng)表中查詢表是否存在主鍵(因一個(gè)表只可能有一個(gè)主鍵,所以只需判斷約束類型即可)
select count(1) into foreignKeyExistedCount from user_constraints t where t.table_name = upper('Test') and t.constraint_type = 'R' and t.constraint_name = '外鍵約束名稱';
--如果不存在,使用快速執(zhí)行語句添加主鍵約束
if foreignKeyExistedCount = 0 then
execute immediate
'alter table Test add constraint 外鍵約束名稱 foreign key references 外鍵引用表(列)';
end if;
end;
總結(jié)
以上所述是小編給大家介紹的Oracle判斷表、列、主鍵是否存在的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Oracle中nvl()和nvl2()函數(shù)實(shí)例詳解
NVL函數(shù)的功能是實(shí)現(xiàn)空值的轉(zhuǎn)換,根據(jù)第一個(gè)表達(dá)式的值是否為空值來返回響應(yīng)的列名或表達(dá)式,下面這篇文章主要給大家介紹了關(guān)于Oracle中nvl()和nvl2()函數(shù)的相關(guān)資料,需要的朋友可以參考下2022-05-05
使用zabbix監(jiān)控oracle表數(shù)據(jù)的方法
有時(shí)候我們需要對表中的數(shù)據(jù)進(jìn)行監(jiān)控,比如筆者的這種場景:?微服務(wù)自己實(shí)現(xiàn)了定時(shí)任務(wù),定時(shí)任務(wù)的執(zhí)行結(jié)果會記錄到某張日志表中,如果定時(shí)任務(wù)執(zhí)行失敗將會對業(yè)務(wù)產(chǎn)生影響,所以筆者用zabbix+python進(jìn)行了監(jiān)控,當(dāng)任務(wù)失敗時(shí)?進(jìn)行告警,需要的朋友可以參考下2024-04-04
Oracle 生成未來三天的整點(diǎn)時(shí)間(步驟詳解)
這篇文章主要介紹了Oracle 生成未來三天的整點(diǎn)時(shí)間,本文通過實(shí)例代碼分步驟給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
Oracle 12c實(shí)現(xiàn)手工建庫而非CDB及CDB創(chuàng)建的方法
這篇文章主要給大家介紹了關(guān)于Oracle 12c實(shí)現(xiàn)手工建庫而非CDB及CDB創(chuàng)建的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用oracle 12c具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10
Oracle數(shù)據(jù)庫中通用的函數(shù)實(shí)例詳解
OracleSQL提供了用于執(zhí)行特定操作的專用函數(shù),這些函數(shù)大大增強(qiáng)了SQL語言的功能,下面這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫中通用函數(shù)的相關(guān)資料,需要的朋友可以參考下2022-03-03
Oracle 分析函數(shù)RANK(),ROW_NUMBER(),LAG()等的使用方法
Oracle分析函數(shù)RANK(),ROW_NUMBER(),LAG()等的使用方法,需要的朋友可以參考下。2009-11-11
Oracle索引(B*tree與Bitmap)的學(xué)習(xí)總結(jié)
本篇文章是對Oracle索引(B*tree與Bitmap)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05

