检查字符串是否为有效日期

Suj*_*tha 2 oracle plsql

我有一个带有字段 sourcefilename 的表,它有 5 条记录。以下是记录。

SN. SOURCEFILENAME
1. 20170215095453_1.Iredell Memorial Hospital Dental Eligibility.xls_INFREPT01.txt
2. Iredell Memorial Hospital Eligibility April 2017.xls_INFREPT01.txt
3. Iredell Memorial Hospital Eligibility March 2017.xls_INFREPT01.txt
4. Iredell Memorial Hospital Eligibility May 2017.xls_INFREPT01.txt
5. Iredell Memorial Hospital October 2016 Dental Eligibility.xls_EligData.txt
Run Code Online (Sandbox Code Playgroud)

我只需要提取前 8 个字符并检查它是否是有效日期。如果它是一个有效日期,则返回 TRUE,否则返回 FALSE。

我试过 ISDATE 函数。还有其他选择吗?

SELECT DISTINCT SubStr(sourcefilename,1,8),
CASE WHEN isdate(SubStr(sourcefilename,1,8),'YYYYMMDD') = 1 THEN 'TRUE' ELSE 'FALSE' END  FROM ai_4451_1_metl;
Run Code Online (Sandbox Code Playgroud)

Wer*_*eit 5

Oracle 12.2 提供了一个新函数VALIDATE_CONVERSION。到目前为止,我从未使用过它,但我认为它会是这样的:

CASE VALIDATE_CONVERSION(SubStr(sourcefilename,1,8) AS DATE, 'YYYYMMDD') 
   WHEN 1 THEN 'TRUE'
   ELSE 'FALSE'
END
Run Code Online (Sandbox Code Playgroud)