ORACLE 修改时间精度

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;

------------------------------------------------------------------------------------------------------------

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值