1、若要修改的字段为空,则可直接修改
2、若要修改的字段不为空则需要一个中介字段来转换,具体操作如下:
方法一、手动添加一个TEST_TIME字段,把要修改的字段转移过来,改一下名称就OK了
方法二、利用存储过程:
1)先执行以下sql生产函数--------------------
CREATE OR REPLACE
PROCEDURE UPDATE_TIME_TO_THREE( pram1 in varchar2,pram2 in varchar2)
IS
tableName varchar2(100) := pram1;
field varchar2(100) := pram2;
name varchar2(100) :='更新时间';
-- 时间精度,根据需求自定义
format varchar2(100) :='SYYYY-MM-DD HH24:MI:SS:FF3';
BEGIN
execute immediate 'ALTER TABLE '||tableName||' ADD (TEST_DATA TIMESTAMP(3))';
execute immediate 'UPDATE '||tableName||' SET TEST_DATA = TO_TIMESTAMP ( to_char ( '|| field ||', '''|| format ||''' ), '''|| format ||''' )';
execute immediate 'ALTER TABLE '||tableName||' DROP ('|| field ||')';
execute immediate 'ALTER TABLE '||tableName||' MODIFY (TEST_DATA NOT NULL )';
execute immediate 'ALTER TABLE '||tableName||' RENAME COLUMN TEST_DATA TO '|| field;
execute immediate 'COMMENT ON COLUMN '||tableName||'.'||field||' IS '''||name||'''';
END UPDATE_TIME_TO_THREE;
---------------------------------------------------------------------------------------------------------
1)执行以下sql 修改时间精度:第一个参数,是要修改的表名,第二个参数是要修改的字段------------
BEGIN
UPDATE_TIME_TO_THREE ('HJ_MENU','UPDATE_TIME');
END;
------------------------------------------------------------------------------------------------------------