码迷,mamicode.com
首页 > 数据库 > 详细

修改Oracle数据库表的主键对应列的数据类型

时间:2015-01-15 23:53:12      阅读:276      评论:0      收藏:0      [点我收藏+]

标签:修改oracle列的数据类型

我们产品从SPC100升级到SPC200的时候,由于数据库表列的数据类型发生了改变,需要写SQL脚本,完成数据库的升级。需要将表T_MOBILE_INDVCONFIG的主键列id从varchar2(100),改成number(17)。可以参考如下SQL:

--将原来的ID列重命名为bak_id
ALTER TABLE T_MOBILE_INDVCONFIG RENAME COLUMN id TO bak_ID;

--添加一个与原来的列一样名字的列
ALTER TABLE T_MOBILE_INDVCONFIG ADD id NUMBER(17); 

--将bak_id中的数据转换类型并保存到新加的ID列
UPDATE T_MOBILE_INDVCONFIG SET ID = CAST(bak_ID AS NUMBER(17));

--删除原有的列
ALTER TABLE T_MOBILE_INDVCONFIG DROP COLUMN bak_ID;

--设置新列属性,这里例子是设置为非空
ALTER TABLE T_MOBILE_INDVCONFIG MODIFY  (ID NUMBER(17) NOT NULL);

--重建主键,因为原来的已经被删除,原来的ID列有索引的也需要重建
ALTER TABLE T_MOBILE_INDVCONFIG  ADD CONSTRAINT PK_SYS_SMSGATE PRIMARY KEY (ID);

修改Oracle数据库表的主键对应列的数据类型

标签:修改oracle列的数据类型

原文地址:http://blog.csdn.net/aitangyong/article/details/42749699

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!