将oracle日期字段转换为20210712 09:00:44格式(24小时制)

将oracle日期字段转换为20210712 09:00:44格式(24小时制),可能会直觉地采用“yyyy-MM-dd HH:mm:ss”的格式作为格式进行转换,但是在Oracle中会引起错误,;原因是SQL中不区分大小写,MM和mm被认为是相同的格式代码,所以Oracle的SQL采用了mi代替分钟。

首先,我们了解一下转换函数有哪些

TO_CHAR 是把日期或数字转换为字符串

TO_DATE 是把字符串转换为数据库中得日期类型转换函数

TO_NUMBER 将字符转化为数字

TO_CHAR

使用TO_CHAR函数处理数字

TO_CHAR(number, ‘格式’)

TO_CHAR(salary,’$99,999.99’);

使用TO_CHAR函数处理日期

TO_CHAR(date,’格式’);

TO_NUMBER

使用TO_NUMBER函数将字符转换为数字

TO_NUMBER(char[, ‘格式’])

TO_DATE

使用TO_DATE函数将字符转换为日期

TO_DATE(char[, ‘格式’])

数字格式格式

9 代表一个数字

0 强制显示0

$ 放置一个$符

L 放置一个浮动本地货币符

. 显示小数点

, 显示千位指示符

日期格式

格式控制 描述

YYYY、YYY、YY 分别代表4位、3位、2位的数字年

YEAR 年的拼写

MM 数字月

MONTH 月的全拼

MON 月的缩写

DD 数字日

DAY 星期的全拼

DY 星期的缩写

AM 表示上午或者下午

HH24、HH12 12小时制或24小时制

MI 分钟

SS 秒钟

SP 数字的拼写

TH 数字的序数词

“特殊字符” 假如特殊字符

HH24:MI:SS AM 15:43:20 PM

日期例子:

SELECT TO_DATE(‘2006-05-01 19:25:34’, ‘YYYY-MM-DD HH24:MI:SS’) FROM DUAL

SELECT TO_DATE(‘2006-05-01 19:25’, ‘YYYY-MM-DD HH24:MI’) FROM DUAL

SELECT TO_DATE(‘2006-05-01 19’, ‘YYYY-MM-DD HH24’) FROM DUAL

SELECT TO_DATE(‘2006-05-01’, ‘YYYY-MM-DD’) FROM DUAL

SELECT TO_DATE(‘2006-05’, ‘YYYY-MM’) FROM DUAL

SELECT TO_DATE(‘2006’, ‘YYYY’) FROM DUAL

实例:

select to_char(发生时间,'yyyymmdd HH24:MI:SS')发生时间  from 表名
将oracle日期字段转换为20210712 09:00:44格式(24小时制)

注意:

1.在使用Oracle的to_date函数来做日期转换时,可能会直觉地采用“yyyy-MM-dd HH:mm:ss”的格式作为格式进行转换,但是在Oracle中会引起错误:“ORA 01810 格式代码出现两次”。如:select to_date(‘2005-01-01 13:14:20′,’yyyy-MM-dd HH24:mm:ss’) from dual;原因是SQL中不区分大小写,MM和mm被认为是相同的格式代码,所以Oracle的SQL采用了mi代替分钟。select to_date(‘2005-01-01 13:14:20′,’yyyy-MM-dd HH24:mi:ss’) from dual;

2.另要以24小时的形式显示出来要用HH24

select to_char(sysdate,’yyyy-MM-dd HH24:mi:ss’) from dual;//mi是分钟

select to_char(sysdate,’yyyy-MM-dd HH24:mm:ss’) from dual;//mm会显示月份

0 条回复 A 作者 M 管理员
    所有的伟大,都源于一个勇敢的开始!
欢迎您,新朋友,感谢参与互动!欢迎您 {{author}},您在本站有{{commentsCount}}条评论