Oralce中的to_date()函数

本文详细介绍了Oracle中to_date()函数的使用方法,包括参数解释、日期格式化代码以及常见错误处理策略。通过示例演示了如何正确地将字符串转换为日期对象,并针对两个典型错误(formatcode出现两次和无效数字)提供了修正方法。

Oralce中的to_date()函数

Oralce中的to_date()函数用于将字符串转换为日期对象,具体使用格式为:
 to_date( string,  [  format_mask  ] ,  [  nls_language  ]  )

string1

要转换的字符串.

format_mask 可选项,日期转换格式.

nls_language 可选项. 指定用于转换字符串的nls language.

其中 format_mask主要有以下几种格式:
Format CodeExplanation
YEARYear, spelled out
YYYY4-digit year
MMMonth (01-12; JAN = 01).
MONAbbreviated name of month.
MONTHName of month, padded with blanks to length of 9 characters.
DDay of week (1-7).
DAYName of day.
DDDay of month (1-31).
DDDDay of year (1-366).
DYAbbreviated name of day.
HHHour of day (1-12).
HH12Hour of day (1-12).
HH24Hour of day (0-23).
MIMinute (0-59).
SSSecond (0-59).
SSSSSSeconds past midnight (0-86399).

[问题]

ORA-01810: format code appears twice
可能是像Java那样指定日期格式,比如:
to_char('2006-06-01 18:00:00' 'yyyy-mm-dd hh:MM:ss')
而在Oracle中的日期格式是不区分大小写的,所以 mm 出现了两次。
正确的写法是:
to_char('2006-06-01 18:00:00' 'yyyy-mm-dd hh:mi:ss')

ORA-01722: invalid number
可能是指定小时为hh,而hh取值范围是 1-12,所以如果指定小时为 0 点将出现这个异常,比如:
to_char('2006-06-01 00:00:00' 'yyyy-mm-dd hh:MM:ss')
正确的写法是:
to_char('2006-06-01 00:00:00' 'yyyy-mm-dd hh24:MM:ss')


调用示例:

SELECT to_char(sysdate,'yyyy-MM-dd HH24:mm:ss') FROM pay_basicinfo


评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值