我想编写一个 Oracle SQL select 语句,告诉它是否可以通过返回代码来解析给定格式的日期字符串 - 失败时返回零(异常),成功时返回正数:
SELECT
CASE
WHEN PARSING SUCCESSFUL (ie. to_date('1-Jan-2001','dd-mon-yy') succeeds) THEN 1
ELSE 0
END
FROM DUAL;
我该怎么写这个?如果解析失败,ELSE条件会返回值吗?我需要在 SELECT 语句本身中执行所有这些检查。请帮忙。
谢谢
迪利普
如果您可以创建一个函数,那么您可以执行以下操作:
SQL小提琴 http://sqlfiddle.com/#!4/e366f/2
Oracle 11g R2 架构设置:
CREATE OR REPLACE FUNCTION is_Valid_Date (
p_date IN VARCHAR2,
p_format IN VARCHAR2 DEFAULT 'DD-MON-YY'
) RETURN NUMBER
IS
d DATE;
BEGIN
d := TO_DATE( p_date, p_format );
RETURN 1;
EXCEPTION
WHEN OTHERS THEN
RETURN 0;
END;
/
Query 1:
SELECT is_Valid_Date( '12-Feb-13' ),
is_Valid_Date( 'XX-Feb-13' )
FROM DUAL
Results http://sqlfiddle.com/#!4/e366f/2/0:
| IS_VALID_DATE('12-FEB-13') | IS_VALID_DATE('XX-FEB-13') |
|----------------------------|----------------------------|
| 1 | 0 |
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)