中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Oracle數據庫如何修改表中字段順序

發布時間:2020-07-09 15:53:15 來源:億速云 閱讀:538 作者:Leah 欄目:MySQL數據庫

本篇文章給大家分享的是有關Oracle數據庫如何修改表中字段順序,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

前言

前段時間,有人問我, 有一個關于Oracle中表字段順序調整的問題。問題就是當設計好表結構之后,后期如果需要往表中增加字段,默認會把該字段放到表的最后,并且字段特別多而我們又想把有關聯性的字段放在一起,這時就要修改字段順序。在修改順序之前,我們先來看看Oracle數據庫表中如何增加字段。

新增字段:

添加字段的語法:alter table tablename add (column datatype [default value][null/not null],….);

實例

創建表結構:

create table test1
(id varchar2(20) not null);

增加一個字段:

alter table test1
add (name varchar2(30) default ‘無名氏' not null);

使用一個SQL語句同時添加三個字段:

alter table test1
add (name varchar2(30) default ‘無名氏' not null,

age integer default 22 not null,

has_money number(9,2)

);

字段順序的修改

第一種原始方法:

刪了重建,這種方法雖然簡單粗暴,但不科學

--新建臨時表以存儲正確的順序
create table A_2 as select (column1,colum2,……A表中的順序) from A_1 ;

--刪除表A_1
drop table A_1;

--新建A_1并從A_2表中賦予其正確的順序和值
create table A_1 as select * from A_2;

--刪除臨時表A_2
drop table A_2;

這種方法對字段較少的表來說還不會顯得太麻煩,但是對于字段較多的表來說就吃力了。

第二種方法(推薦):

1、首先需要sys或system權限操作

2、查詢需要更改表的ID

select object_id
 from all_objects
 where owner = 'ITHOME'
 and object_name = 'TEST';

注:ITHOME為用戶,TEST是要更改的表,表名要大寫

3、通過ID查出該表所有字段的順序

select obj#, col#, name 
 from sys.col$ 
 where obj# = '103756' order by col#

Oracle數據庫如何修改表中字段順序

4、修改順序

update sys.col$ set col#=2 where obj#=103756 and name='AGE';
update sys.col$ set col#=3 where obj#=103756 and name='NAME';

或直接在第三步的語句后面加 for update 進行修改

最后commit提交 并且重啟Oracle服務

以上就是Oracle數據庫如何修改表中字段順序,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乐都县| 砀山县| 修文县| 平谷区| 丽水市| 屏东县| 兴国县| 阿合奇县| 南投县| 慈利县| 拜泉县| 剑阁县| 鸡东县| 宜春市| 赫章县| 寿阳县| 池州市| 永春县| 竹山县| 上犹县| 郴州市| 乌恰县| 鱼台县| 景宁| 佛坪县| 福贡县| 东乌珠穆沁旗| 福鼎市| 梧州市| 台安县| 富平县| 城口县| 洮南市| 东乡族自治县| 黎城县| 子洲县| 临朐县| 桃园县| 临武县| 嵊州市| 吉水县|