解析日期后从Oracle Select语句返回号码 [英] Return number from Oracle Select statement after parsing date

查看:173
本文介绍了解析日期后从Oracle Select语句返回号码的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想编写一个Oracle SQL select语句,该语句告诉它是否可以通过在失败时异常返回一个代码为零(例外)来解析给定格式的日期字符串,如果成功则返回一个正数:

I want to write a Oracle SQL select statement that tells if it could parse a date string in the given format by returning a code - zero on failure (exception) and a positive number in case of success :

    SELECT
     CASE
      WHEN PARSING SUCCESSFUL (ie. to_date('1-Jan-2001','dd-mon-yy') succeeds) THEN 1
      ELSE 0
     END  
    FROM DUAL;

我该如何写?如果解析失败,ELSE条件会返回一个值吗?我需要在SELECT语句本身中执行所有这些检查。请帮助。

How do I write this ? If the parsing fails, will the ELSE condition return a value ? I need to do all these checks in the SELECT statement itself. Please help.

感谢
Dileep

Thanks Dileep

推荐答案

如果您可以创建一个函数,然后您可以执行以下操作:

If you can create a function then you can do something like:

SQL Fiddle

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;
/

查询1

SELECT is_Valid_Date( '12-Feb-13' ),
       is_Valid_Date( 'XX-Feb-13' )
FROM DUAL

结果

Results:

| IS_VALID_DATE('12-FEB-13') | IS_VALID_DATE('XX-FEB-13') |
|----------------------------|----------------------------|
|                          1 |                          0 |

这篇关于解析日期后从Oracle Select语句返回号码的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆