今天同事问我一个问题他说在一张2000万的表上增加了一个字段并字段一个默认值,执行这条语句(alter table tablename add new_col default ‘col’)一个小时没有执行完,问我有没有其他解决方法我查了一下资料发现Oracle11g中,在添加一个包含DEFAULT值的NOT NULL字段,Oracle不会去更新现有的数据,Oracle需要做的不过是将默认值以及对应的表信息、列信息一起存储在一个新增数据字典表ecol$中。这张表利用BLOB字段存储ALTER TABLE添加的DEFAULT值然后我测试一下情况(在11g中测试
alter table tablename add new_col default ‘col’ 后代not null和不带not null的区别)1.新建一张表testSQL> create table test (id number,name varchar(10));表已创建。2.向test表中插入500000记录SQL> begin 2 for i in 1..500000 loop 3 insert into test values(i,"jack"); 4 end loop; 5 end; 6 /PL/SQL 过程已成功完成。SQL> select count(1) from test; COUNT(1)---------- 500000SQL>SQL> set timing on 3.向表中添加一个新的字段NEW_COL1带有默认值如下语句
不带NOT NULLALTER TABLE t ADD NEW_COL1 CHAR(10) DEFAULT "TESTCOLUMN"SQL> ALTER TABLE test ADD NEW_COL1 CHAR(10) DEFAULT "TESTCOLUMN";表已更改。已用时间: 00: 00: 43.23SQL>
PL/SQL客户端连Oracle很快就断开问题的解决Oracle 删除表名命名不合法的表相关资讯 Oracle 11g
- Oracle 11g导入到10g引起的错误 (11/16/2015 10:55:27)
- Oracle 11g 导库导不出空表问题 (08/19/2015 19:55:58)
- Oracle 11g统计信息收集--多列统计 (07/24/2015 10:32:39)
| - Oracle 11gClone安装方法 (08/24/2015 20:25:41)
- Oracle 11g中和SQL TUNING相关的新 (08/12/2015 11:22:52)
- Oracle 11g数据泵详解 (07/08/2015 08:29:51)
|
本文评论 查看全部评论 (0)