Oracle判斷表、列、主鍵是否存在的方法
在編寫(xiě)程序時(shí),數(shù)據(jù)庫(kù)結(jié)構(gòu)會(huì)經(jīng)常變化,所以經(jīng)常需要編寫(xiě)一些數(shù)據(jù)庫(kù)腳本,編寫(xiě)完成后需發(fā)往現(xiàn)場(chǎng)執(zhí)行,如果已經(jīng)存在或者重復(fù)執(zhí)行,有些腳本會(huì)報(bào)錯(cuò),所以需要判斷其是否存在,現(xiàn)在我就把經(jīng)常用到的一些判斷方法和大家分享下:
一。判斷Oracle表是否存在的方法
declare tableExistedCount number; --聲明變量存儲(chǔ)要查詢的表是否存在 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í)行語(yǔ)句創(chuàng)建新表 execute immediate 'create table Test --創(chuàng)建測(cè)試表 (ID number not null,Name = varchar2(20) not null)'; end if; end;
二。判斷Oracle表中的列是否存在的方法
declare columnExistedCount number; --聲明變量存儲(chǔ)要查詢的表中的列是否存在 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í)行語(yǔ)句添加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; --聲明變量存儲(chǔ)要查詢的表中的列是否存在 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í)行語(yǔ)句添加主鍵約束 if primaryKeyExistedCount = 0 then execute immediate 'alter table Test add constraint PK_Test_ID primary key(id)'; end if; end;
四。判斷Oracle表是否存在外鍵的方法
declare foreignKeyExistedCount number; --聲明變量存儲(chǔ)要查詢的表中的列是否存在 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í)行語(yǔ)句添加主鍵約束 if foreignKeyExistedCount = 0 then execute immediate 'alter table Test add constraint 外鍵約束名稱 foreign key references 外鍵引用表(列)'; end if; end;
總結(jié)
以上所述是小編給大家介紹的Oracle判斷表、列、主鍵是否存在的方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
winserver 2012R2 安裝oracle及創(chuàng)建表流程(推薦)
這篇文章主要介紹了winserver 2012R2 安裝oracle及創(chuàng)建表流程,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-06-06oracle分區(qū)表之hash分區(qū)表的使用及擴(kuò)展
Hash分區(qū)是Oracle實(shí)現(xiàn)表分區(qū)的三種基本分區(qū)方式之一。對(duì)于那些無(wú)法有效劃分分區(qū)范圍的大表,或者出于某些特殊考慮的設(shè)計(jì),需要使用Hash分區(qū),下面介紹使用方法2014-01-01Oracle/SQL中TO_DATE函數(shù)詳細(xì)實(shí)例解析
Oracle to_date()函數(shù)用于日期轉(zhuǎn)換,下面這篇文章主要給大家介紹了關(guān)于Oracle/SQL中TO_DATE函數(shù)的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用oracle具有一定的參考解決價(jià)值,需要的朋友可以參考下2024-06-06Oracle查看邏輯讀、物理讀資源占用排行的SQL語(yǔ)句
這篇文章主要介紹了Oracle查看邏輯讀、物理讀資源占用排行的SQL語(yǔ)句,需要的朋友可以參考下2014-10-10oracle冷備份恢復(fù)和oracle異機(jī)恢復(fù)使用方法
這篇文章主要介紹了oracle冷備份恢復(fù)和oracle異機(jī)恢復(fù)方法,冷備份發(fā)生在數(shù)據(jù)庫(kù)已經(jīng)正常關(guān)閉的情況下,下面是使用方法,需要的朋友可以參考下2014-03-03oracle中commit之后進(jìn)行數(shù)據(jù)回滾的方法
這篇文章主要介紹了oracle中commit之后如何進(jìn)行數(shù)據(jù)回滾,本文給大家分享兩種方法,每種方法都給大家介紹的比較詳細(xì),需要的朋友可以參考下2021-12-12Oracle用戶密碼過(guò)期如何修改永不過(guò)期
針對(duì)不同的業(yè)務(wù)場(chǎng)景會(huì)有不一樣的業(yè)務(wù)需求,oracle的用戶密碼,生產(chǎn)環(huán)境肯定需要定期進(jìn)行更換,保證安全性,但是也同樣會(huì)有需求要求oracle用戶的密碼永遠(yuǎn)不過(guò)期,這篇文章主要給大家介紹了關(guān)于Oracle用戶密碼過(guò)期如何修改永不過(guò)期的相關(guān)資料,需要的朋友可以參考下2024-03-03