TIMESTAMP类型插入到VARCHAR2后转成DATE类型和指定格式字符串

来源:互联网 发布:php单例模式代码 编辑:程序博客网 时间:2024/04/30 10:38
    Oracle中的由于TIMESTAMP类型数据未做TO_CHAR格式化处理直接插入到VARCHAR2类型字段中。在VARCHAR2存储的格式为27-NOV-15 12.00.00.000000 PM和27-NOV-15 12.00.00.000000 AM这种格式。需求是将数据转换成指定的VARCHAR2(14)类型。
解决办法:将字符串转换成TIMESTAMP类型之后再转换成VARCHAR2(14)类型

SELECT TO_CHAR(CAST('19-NOV-15 11.00.00.000000000 PM' AS TIMESTAMP), 'YYYYMMDDHH24MISS') FROM DUAL;

疑惑解答:

27-NOV-15 12.00.00.000000 PM    是指中午十二点。27-NOV-15 12.00.00.000000 AM    是指零晨零点。看到这个字符串可能会以为是中午十二点,转换成TIMESTAMP类型再转成VARCHAR2(14)类型后为20151127000000可能会误认为转换错误,其实是正确的。
0 0
原创粉丝点击