您的位置:首页 > 其它

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

2015-11-27 20:58 267 查看
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可能会误认为转换错误,其实是正确的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: