欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle判斷表、列、主鍵是否存在的方法

 更新時(shí)間:2018年04月24日 15:04:01   作者:特務(wù)小強(qiáng)  
這篇文章主要介紹了Oracle判斷表、列、主鍵是否存在的方法,下面是小編之家小編給大家?guī)?lái)的一些判斷方法和大家分享下

在編寫(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)建表流程(推薦)

    這篇文章主要介紹了winserver 2012R2 安裝oracle及創(chuàng)建表流程,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-06-06
  • Oracle SID存在解決方法

    Oracle SID存在解決方法

    如果有個(gè)別DLL文件無(wú)法刪除的情況,則不用理會(huì),重新啟動(dòng),開(kāi)始新的安裝
    2009-06-06
  • oracle分區(qū)表之hash分區(qū)表的使用及擴(kuò)展

    oracle分區(qū)表之hash分區(qū)表的使用及擴(kuò)展

    Hash分區(qū)是Oracle實(shí)現(xiàn)表分區(qū)的三種基本分區(qū)方式之一。對(duì)于那些無(wú)法有效劃分分區(qū)范圍的大表,或者出于某些特殊考慮的設(shè)計(jì),需要使用Hash分區(qū),下面介紹使用方法
    2014-01-01
  • Oracle Index索引無(wú)效的原因與解決方法

    Oracle Index索引無(wú)效的原因與解決方法

    這篇文章主要給大家介紹了關(guān)于Oracle Index索引無(wú)效的原因與解決方法,文中通過(guò)示例代碼以及圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Oracle/SQL中TO_DATE函數(shù)詳細(xì)實(shí)例解析

    Oracle/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-06
  • Oracle查看邏輯讀、物理讀資源占用排行的SQL語(yǔ)句

    Oracle查看邏輯讀、物理讀資源占用排行的SQL語(yǔ)句

    這篇文章主要介紹了Oracle查看邏輯讀、物理讀資源占用排行的SQL語(yǔ)句,需要的朋友可以參考下
    2014-10-10
  • oracle冷備份恢復(fù)和oracle異機(jī)恢復(fù)使用方法

    oracle冷備份恢復(fù)和oracle異機(jī)恢復(fù)使用方法

    這篇文章主要介紹了oracle冷備份恢復(fù)和oracle異機(jī)恢復(fù)方法,冷備份發(fā)生在數(shù)據(jù)庫(kù)已經(jīng)正常關(guān)閉的情況下,下面是使用方法,需要的朋友可以參考下
    2014-03-03
  • oracle中commit之后進(jìn)行數(shù)據(jù)回滾的方法

    oracle中commit之后進(jìn)行數(shù)據(jù)回滾的方法

    這篇文章主要介紹了oracle中commit之后如何進(jìn)行數(shù)據(jù)回滾,本文給大家分享兩種方法,每種方法都給大家介紹的比較詳細(xì),需要的朋友可以參考下
    2021-12-12
  • Oracle用戶密碼過(guò)期如何修改永不過(guò)期

    Oracle用戶密碼過(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
  • Oracle 8i在P4上的安裝

    Oracle 8i在P4上的安裝

    Oracle 8i在P4上的安裝...
    2007-03-03

最新評(píng)論