首页 > 代码库 > 修改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);
修改Oracle数据库表的主键对应列的数据类型
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。