搜尋
首頁資料庫Oracleoracle資料庫怎麼修改字段

oracle資料庫怎麼修改字段

Mar 02, 2022 pm 06:13 PM
oracle資料庫

在oracle中,可以利用「ALTER TABLE MODIFY」語句來修改字段,語法為「ALTER TABLE 表名MODIFY 字段名需要執行的操作;」;常用操作有:修改列的可見性、更改列的預設值、修改虛擬列的表達式等。

oracle資料庫怎麼修改字段

本教學操作環境:Windows7系統、Oracle 11g版、Dell G3電腦。

oracle資料庫怎麼修改字段

在oracle中,可以利用「ALTER TABLE MODIFY」語句來修改字段,更改現有字段的定義。

要變更表格中列的定義,請如下所示使用ALTER TABLE MODIFY列語法:

ALTER TABLE 表名 
MODIFY 字段名 需要执行的操作;

語句很直接。要修改表格的列,需要指定要執行的列名,表名和操作。

Oracle允許執行多種操作,但以下是主要常用的操作:

  • #修改列的可見性

  • 允許或不允許NULL值

  • 縮短或擴大列的大小

  • #更改列的預設值

  • #修改虛擬列的表達式

要修改多個列,請使用下列語法:

ALTER TABLE 表名
MODIFY (
    字段名1 action,
    字段名2 action,
    ...
);

Oracle ALTER TABLE MODIFY列範例

#首先,為示範建立一個名為accounts的新表:

-- 12c语法
CREATE TABLE accounts (
    account_id NUMBER GENERATED BY DEFAULT AS IDENTITY,
    first_name VARCHAR2(25) NOT NULL,
    last_name VARCHAR2(25) NOT NULL,
    email VARCHAR2(100),
    phone VARCHAR2(12) ,
    full_name VARCHAR2(51) GENERATED ALWAYS AS( 
            first_name || ' ' || last_name
    ),
    PRIMARY KEY(account_id)
);

其次,向accounts表中插入一些行:

INSERT INTO accounts(first_name,last_name,phone)
VALUES('Trinity',
       'Knox',
       '410-555-0197');


INSERT INTO accounts(first_name,last_name,phone)
VALUES('Mellissa',
       'Porter',
       '410-555-0198');


INSERT INTO accounts(first_name,last_name,phone)
VALUES('Leeanna',
       'Bowman',
       '410-555-0199');

第三,透過使用下面的SELECT語句驗證插入操作:

SELECT
    *
FROM
    accounts;

執行上面查詢語句,得到以下結果-

oracle資料庫怎麼修改字段

1. 修改列的可見性

在Oracle 12c中,可以將表列定義為不可見或可見。不可見列不可用於查詢,如:

SELECT
    *
FROM
    table_name;

或者,

DESCRIBE table_name;

都是查到不到不可見列的。

但是,可以透過在查詢中明確指定不可見列來查詢:

SELECT
    invisible_column_1,
    invisible_column_2
FROM
    table_name;

預設情況下,表列是可見的。可以在建立表格或使用ALTER TABLE MODIFY列語句時定義不可見列。

例如,以下語句使full_name列不可見:

ALTER TABLE accounts 
MODIFY full_name INVISIBLE;

執行再次查詢表中數據,得到以下結果-

oracle資料庫怎麼修改字段

以下語句傳回accounts表除了full_name列以外的所有欄位中傳回資料:

SELECT
    *
FROM
    accounts;

這是因為full_name列是不可見的。若要將列從不可見變為可見,請使用下列語句:

ALTER TABLE accounts 
MODIFY full_name VISIBLE;

2. 允許或不允許null範例

下列語句將email列更改為接受非空(not null)值:

ALTER TABLE accounts 
MODIFY email VARCHAR2( 100 ) NOT NULL;

但是,Oracle發出以下錯誤:

SQL Error: ORA-02296: cannot enable (OT.) - null values found

因為當將列從可為null改為not null時,必須確保現有資料符合新限制條件(也就是說,如果原來資料中NULL是不行的)。

為了解決這個問題,首先更新email列的值:

UPDATE 
    accounts
SET 
    email = LOWER(first_name || '.' || last_name || '@oraok.com') ;

請注意,LOWER()函數將字串轉換為小寫字母。

然後改變email列的限制:

ALTER TABLE accounts 
MODIFY email VARCHAR2( 100 ) NOT NULL;

現在,它應該就會如預期般運作了。

3. 擴大或縮短列範例的大小

#假設要將國際程式碼新增到phone列上,例如:前綴加上 86。在修改列的值之前,必須使用以下語句擴大phone列的大小:

ALTER TABLE accounts 
MODIFY phone VARCHAR2( 24 );

現在,我們可以更新電話號碼的資料了:

UPDATE
    accounts
SET
    phone = '+86 ' || phone;

以下語句驗證更新:

SELECT
    *
FROM
    accounts;

執行上面查詢語句結果中,應該可以看到原始電話號碼前綴有加上 86的國際區號了。

oracle資料庫怎麼修改字段

要縮短列的大小,請確保列中的所有資料都符合新的大小。

例如,嘗試將phone列的大小縮減到12個字元:

ALTER TABLE accounts 
MODIFY phone VARCHAR2( 12 );

Oracle資料庫發出以下錯誤:

SQL Error: ORA-01441: cannot decrease column length because some  value is too big

要解決這個問題,首先,應該從電話號碼中刪除國際代碼(即: 86):

UPDATE
    accounts
SET
    phone = REPLACE(
        phone,
        '+86 ',
        ''
    );

REPLACE()函數用一個新的子字串替換一個子字串。在這種情況下,它將用空字串替換 86

然後縮短phone列的大小:

ALTER TABLE accounts 
MODIFY phone VARCHAR2( 12 );

#4. 修改虛擬列

##假設以以下兩列的格式填入全名:

last_name, first_name
為此,可以變更虛擬列

full_name的表達式,如下所示:

ALTER TABLE accounts 
MODIFY full_name VARCHAR2(52) 
GENERATED ALWAYS AS (last_name || ', ' || first_name);

以下语句验证修改:

SELECT
    *
FROM
    accounts;

执行上面查询语句,可以看到以下结果 

oracle資料庫怎麼修改字段

5. 修改列的默认值

添加一个名为status的新列,默认值为1accounts表中。参考以下语句 -

ALTER TABLE accounts
ADD status NUMBER( 1, 0 ) DEFAULT 1 NOT NULL ;

当执行了该语句,就会将accounts表中的所有现有行的status列中的值设置为1

要将status列的默认值更改为0,请使用以下语句:

ALTER TABLE accounts 
MODIFY status DEFAULT 0;

可以在accounts表中添加一个新行来检查status列的默认值是0还是1

INSERT INTO accounts ( first_name, last_name, email, phone )
VALUES ( 'Julia',
         'Madden',
         'julia.madden@oraok.com',
         '410-555-0200' );

现在,查询accounts表中的数据:

SELECT
  *
FROM
  accounts;

执行上面查询语句,应该看类似下面的结果 

oracle資料庫怎麼修改字段

正如所看到的那样,ID4的账户的status列的值是0

推荐教程:《Oracle教程

以上是oracle資料庫怎麼修改字段的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
甲骨文:從數據庫到雲服務甲骨文:從數據庫到雲服務May 02, 2025 am 12:05 AM

Oracle從數據庫到雲服務的演變歷程表明其技術實力和市場洞察力強大。 1.Oracle起源於上世紀70年代,以關係數據庫管理系統聞名,推出了PL/SQL等創新功能。 2.Oracle數據庫核心是關係模型和SQL優化,支持多租戶架構。 3.Oracle雲服務通過OCI提供IaaS、PaaS和SaaS,AutonomousDatabase表現出色。 4.使用Oracle時需注意許可模式複雜、性能優化和雲遷移中的數據安全問題。

Oracle和MySQL:探索數據管理方法Oracle和MySQL:探索數據管理方法May 01, 2025 am 12:13 AM

Oracle適合需要高性能和復雜查詢的企業級應用,MySQL適用於快速開發和部署的Web應用。 1.Oracle支持複雜事務處理和高可用性,適用於金融和大型ERP系統。 2.MySQL強調易用性和開源支持,廣泛用於中小型企業和互聯網項目。

MySQL與Oracle:查看用戶體驗MySQL與Oracle:查看用戶體驗Apr 30, 2025 am 12:12 AM

MySQL和Oracle在用戶體驗上的差異主要體現在:1.MySQL簡潔易用,適合快速上手和靈活性高的場景;2.Oracle功能強大,適合需要企業級支持的場景。 MySQL的開源和免費特性吸引初創公司和個人開發者,而Oracle的複雜功能和工具則滿足大型企業的需求。

MySQL和Oracle:探索性能和可伸縮性MySQL和Oracle:探索性能和可伸縮性Apr 29, 2025 am 12:12 AM

MySQL和Oracle在性能和可擴展性上的區別在於:1.MySQL在小型到中型數據集上表現更好,適合快速擴展和高效讀寫;2.Oracle在處理大型數據集和復雜查詢時更具優勢,適合高可用性和復雜業務邏輯。 MySQL通過主從復制和分片技術實現擴展,而Oracle通過RAC實現高可用性和擴展性。

Oracle軟件執行什麼:關鍵功能和功能Oracle軟件執行什麼:關鍵功能和功能Apr 28, 2025 am 12:08 AM

Oracle軟件的關鍵功能包括多租戶架構、高級分析和數據挖掘、實時應用集群(RAC)以及自動化管理和監控。 1)多租戶架構允許在一個數據庫實例中管理多個獨立的數據庫,簡化管理並降低成本。 2)高級分析和數據挖掘工具如OracleAdvancedAnalytics和OracleDataMining幫助從數據中提取洞察。 3)實時應用集群(RAC)提供高可用性和可擴展性,提高系統容錯能力和性能。 4)自動化管理和監控工具如OracleEnterpriseManager(OEM)自動化日常維護任務並實時監控數

甲骨文的影響:數據管理及其他甲骨文的影響:數據管理及其他Apr 27, 2025 am 12:11 AM

Oracle在数据管理和企业应用领域具有深远影响,其数据库以可靠性、可扩展性和安全性著称,广泛应用于金融、医疗和政府等行业。Oracle的影响力还扩展到中间件和云计算领域,如WebLogicServer和OracleCloudInfrastructure(OCI),提供创新解决方案。尽管面临开源数据库和云计算市场竞争,Oracle通过不断创新保持领先地位。

甲骨文:探索公司的使命和價值甲骨文:探索公司的使命和價值Apr 26, 2025 am 12:06 AM

Oracle的使命是“幫助人們看到數據的價值”,其核心價值觀包括:1)客戶至上,2)誠信,3)創新,4)團隊合作。這些價值觀指導Oracle在市場中的戰略決策和業務創新。

Oracle的核心功能:提供數據庫解決方案Oracle的核心功能:提供數據庫解決方案Apr 25, 2025 am 12:06 AM

Oracle數據庫是一種關係型數據庫管理系統,支持SQL和對象關係模型,提供數據安全和高可用性。 1.Oracle數據庫的核心功能包括數據存儲、檢索、安全和備份恢復。 2.其工作原理涉及多層存儲結構、MVCC機制和優化器。 3.基本用法包括創建表、插入和查詢數據;高級用法涉及存儲過程和触發器。 4.性能優化策略包括使用索引、優化SQL語句和內存管理。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。