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

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

 更新時間:2018年04月24日 15:04:01   作者:特務(wù)小強(qiáng)  
這篇文章主要介紹了Oracle判斷表、列、主鍵是否存在的方法,下面是小編之家小編給大家?guī)淼囊恍┡袛喾椒ê痛蠹曳窒硐?/div>

在編寫程序時,數(shù)據(jù)庫結(jié)構(gòu)會經(jīng)常變化,所以經(jīng)常需要編寫一些數(shù)據(jù)庫腳本,編寫完成后需發(fā)往現(xiàn)場執(zhí)行,如果已經(jīng)存在或者重復(fù)執(zhí)行,有些腳本會報錯,所以需要判斷其是否存在,現(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)表中查詢表是否存在主鍵(因一個表只可能有一個主鍵,所以只需判斷約束類型即可)
    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)表中查詢表是否存在主鍵(因一個表只可能有一個主鍵,所以只需判斷約束類型即可)
    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判斷表、列、主鍵是否存在的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • winserver 2012R2 安裝oracle及創(chuàng)建表流程(推薦)

    winserver 2012R2 安裝oracle及創(chuàng)建表流程(推薦)

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

    Oracle SID存在解決方法

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

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

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

    Oracle Index索引無效的原因與解決方法

    這篇文章主要給大家介紹了關(guān)于Oracle Index索引無效的原因與解決方法,文中通過示例代碼以及圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(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)資料,文中通過代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用oracle具有一定的參考解決價值,需要的朋友可以參考下
    2024-06-06
  • Oracle查看邏輯讀、物理讀資源占用排行的SQL語句

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

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

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

    這篇文章主要介紹了oracle冷備份恢復(fù)和oracle異機(jī)恢復(fù)方法,冷備份發(fā)生在數(shù)據(jù)庫已經(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用戶密碼過期如何修改永不過期

    Oracle用戶密碼過期如何修改永不過期

    針對不同的業(yè)務(wù)場景會有不一樣的業(yè)務(wù)需求,oracle的用戶密碼,生產(chǎn)環(huán)境肯定需要定期進(jìn)行更換,保證安全性,但是也同樣會有需求要求oracle用戶的密碼永遠(yuǎn)不過期,這篇文章主要給大家介紹了關(guān)于Oracle用戶密碼過期如何修改永不過期的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • Oracle 8i在P4上的安裝

    Oracle 8i在P4上的安裝

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

最新評論