0

0

Oracle 11g增加列,并带默认值的新特性

php中文网

php中文网

发布时间:2016-06-07 16:47:31

|

1324人浏览过

|

来源于php中文网

原创

在Oracle 11g以前,如果要在一个大表中增加一列,并设置默认值,那将是一个非常悲剧的事情.有些时候不得不选择在线重定义功能来实现

oracle 11g增加列,并带默认值的新特性

[日期:2014-04-05] 来源:Linux社区  作者:Linux [字体:]

在Oracle 11g以前,如果要在一个大表中增加一列,并设置默认值,那将是一个非常悲剧的事情.有些时候不得不选择在线重定义功能来实现该需求.而在11g中增加新列并设置默认值,只是简单的修改数据字典来实现该功能,大大提供效率
10g加列(默认值)

SQL> select * from v$version;

 

BANNER

----------------------------------------------------------------

Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Prod

PL/SQL Release 10.2.0.1.0 - Production

CORE 10.2.0.1.0 Production

TNS for Linux: Version 10.2.0.1.0 - Production

NLSRTL Version 10.2.0.1.0 - Production

 

SQL> create table t_xifenfei

2 as select object_id,object_name from dba_objects;

 

Table created.

 

SQL> select count(*) from t_xifenfei;

 

COUNT(*)

----------

49827

 

SQL> desc t_xifenfei

Name Null? Type

----------------------------------------- -------- ----------------------------

OBJECT_ID NUMBER

OBJECT_NAME VARCHAR2(128)

 

SQL> set timing on

SQL> alter table t_xifenfei add c_xff varchar2(100) default 'www.xifenfei.com' not null;

 

Table altered.

 

Elapsed: 00:00:06.13

--使用了6秒钟

 

SQL> select rowid,

2 dbms_rowid.rowid_relative_fno(rowid)rel_fno,

3 dbms_rowid.rowid_block_number(rowid)blockno,

4 dbms_rowid.rowid_row_number(rowid) rowno

5 from t_xifenfei where object_name='OBJ$';

 

ROWID REL_FNO BLOCKNO ROWNO

------------------ ---------- ---------- ----------

宣小二
宣小二

宣小二:媒体发稿平台,自媒体发稿平台,短视频矩阵发布平台,基于AI驱动的企业自助式投放平台。

下载

AAAMwJAAEAAAAB8AAr 4 124124 43

 

SQL> alter system dump datafile 4 block 124124;

 

System altered.

 

Elapsed: 00:00:00.08

11g增加列(默认值)

SQL> select * from v$version;

 

BANNER

-----------------------------------------------------------------------

Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - Production

PL/SQL Release 11.2.0.3.0 - Production

CORE 11.2.0.3.0 Production

TNS for Linux: Version 11.2.0.3.0 - Production

NLSRTL Version 11.2.0.3.0 - Production

 

SQL> create table t_xifenfei

2 as select object_id,object_name from dba_objects;

 

Table created.

 

SQL> select count(*) from t_xifenfei;

 

COUNT(*)

----------

74605

 

SQL> select rowid,

2 dbms_rowid.rowid_relative_fno(rowid)rel_fno,

3 dbms_rowid.rowid_block_number(rowid)blockno,

4 dbms_rowid.rowid_row_number(rowid) rowno

5 from t_xifenfei where object_name='OBJ$';

 

ROWID REL_FNO BLOCKNO ROWNO

------------------ ---------- ---------- ----------

AAASpRAAEAAAACrAAu 4 171 46

 

SQL> alter system dump datafile 4 block 171;

 

System altered.

 

 

SQL> set timing on

SQL> alter table t_xifenfei add c_xff varchar2(100) default 'www.xifenfei.com' not null;

 

Table altered.

 

Elapsed: 00:00:00.19

--只是使用了0.19秒

 

SQL> select rowid,

2 dbms_rowid.rowid_relative_fno(rowid)rel_fno,

3 dbms_rowid.rowid_block_number(rowid)blockno,

4 dbms_rowid.rowid_row_number(rowid) rowno

5 from t_xifenfei where object_name='OBJ$';

 

ROWID REL_FNO BLOCKNO ROWNO

------------------ ---------- ---------- ----------

AAASpRAAEAAAACrAAu 4 171 46

 

Elapsed: 00:00:00.04

SQL> alter system dump datafile 4 block 171;

 

System altered.

通过10g和11g的增加相同列和默认值的对比可以发现,11g的速度要比10g快很多很多,下面我们通过上面dump出来相关的数据块来分析原因
dump分析
11g增加列之前dump

tab 0, row 0, @0x1f74

tl: 12 fb: --H-FL-- lb: 0x0 cc: 2

col 0: [ 2] c1 15

col 1: [ 5] 49 43 4f 4c 24

tab 0, row 1, @0x1f66

tl: 14 fb: --H-FL-- lb: 0x0 cc: 2

col 0: [ 2] c1 2f

col 1: [ 7] 49 5f 55 53 45 52 31

tab 0, row 2, @0x1f5b

tl: 11 fb: --H-FL-- lb: 0x0 cc: 2

col 0: [ 2] c1 1d

col 1: [ 4] 43 4f 4e 24

11g增加列之后dump

tab 0, row 0, @0x1f74

tl: 12 fb: --H-FL-- lb: 0x0 cc: 2

col 0: [ 2] c1 15

col 1: [ 5] 49 43 4f 4c 24

tab 0, row 1, @0x1f66

tl: 14 fb: --H-FL-- lb: 0x0 cc: 2

col 0: [ 2] c1 2f

col 1: [ 7] 49 5f 55 53 45 52 31

tab 0, row 2, @0x1f5b

tl: 11 fb: --H-FL-- lb: 0x0 cc: 2

col 0: [ 2] c1 1d

col 1: [ 4] 43 4f 4e 24

tab 0, row 3, @0x1f4f

tl: 12 fb: --H-FL-- lb: 0x0 cc: 2

col 0: [ 2] c1 10

col 1: [ 5] 55 4e 44 4f 24

10g增加列之后dump
因为10g在没有增加列之前的dump和11g未增加列之前类似,所以未dump出来

tab 0, row 0, @0x1f63

tl: 29 fb: --H-FL-- lb: 0x2 cc: 3

col 0: [ 2] c1 15

col 1: [ 5] 49 43 4f 4c 24

col 2: [16] 77 77 77 2e 78 69 66 65 6e 66 65 69 2e 63 6f 6d

tab 0, row 1, @0x1f44

tl: 31 fb: --H-FL-- lb: 0x2 cc: 3

col 0: [ 2] c1 2d

col 1: [ 7] 49 5f 55 53 45 52 31

col 2: [16] 77 77 77 2e 78 69 66 65 6e 66 65 69 2e 63 6f 6d

tab 0, row 2, @0x1f28

tl: 28 fb: --H-FL-- lb: 0x2 cc: 3

col 0: [ 2] c1 1d

col 1: [ 4] 43 4f 4e 24

col 2: [16] 77 77 77 2e 78 69 66 65 6e 66 65 69 2e 63 6f 6d

tab 0, row 3, @0x1f0b

tl: 29 fb: --H-FL-- lb: 0x2 cc: 3

col 0: [ 2] c1 10

col 1: [ 5] 55 4e 44 4f 24

col 2: [16] 77 77 77 2e 78 69 66 65 6e 66 65 69 2e 63 6f 6d

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

2

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

golang 循环遍历
golang 循环遍历

本专题整合了golang循环遍历相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.31

Golang人工智能合集
Golang人工智能合集

本专题整合了Golang人工智能相关内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

76

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

73

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

67

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

19

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
ECMAScript6 / ES6---十天技能课堂
ECMAScript6 / ES6---十天技能课堂

共25课时 | 2万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 820人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号