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可能会误认为转换错误,其实是正确的。