oracle修改主键列,修改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);

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值