【问题标题】:Return number from Oracle Select statement after parsing date解析日期后从 Oracle Select 语句返回数字
【发布时间】:2014-01-18 11:53:16
【问题描述】:

我想编写一个 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 oracle parsing date case


【解决方案1】:

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

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 |

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-02-12
    • 2015-11-19
    • 2016-06-23
    相关资源
    最近更新 更多