Oracle改动字段类型

因为需求变动。现要将一个类型NUMBER(8,2)的字段类型改为 char。
大体思路例如以下:
      将要更改类型的字段名改名以备份。然后加入一个与要更改类型的字段名同名的字段(原字段已经改名)。然后更新数据,最后删除改名备份的字段。



 下面操作在 Oracle 10.2.0.1.0 中通过。



/*改动原字段名*/
ALTER TABLE 表名 RENAME COLUMN 字段名 TO 字段名1;


/*加入一个和原字段同名的字段*/
ALTER TABLE 表名 ADD 字段名  VARCHAR2(30);


/*
将原来的数据更新到新字段中
这是要注意。一定要显示进行数据类型转换(不同于MSSQL)
*/


UPDATE 表名 SET 字段名 = CAST(字段名1 AS VARCHAR2(30));


/*删除原来的备份字段*/
ALTER TABLE 表名 DROP COLUMN 字段名1;

原文地址:https://www.cnblogs.com/wzzkaifa/p/7161847.html