Oracle
 sql >> Datenbank >  >> RDS >> Oracle

Wie finde ich eine bestimmte Maske in einer Zeichenfolge - Oracle?

Klingt nach einem Datenmodellproblem (Speichern eines Datums in einer Zeichenfolge).

Aber da es passiert und wir Dinge manchmal nicht kontrollieren oder ändern können, behalte ich normalerweise eine Funktion wie diese bei:

CREATE OR REPLACE FUNCTION safe_to_date (p_string        IN VARCHAR2,
                                         p_format_mask   IN VARCHAR2,
                                         p_error_date    IN DATE DEFAULT NULL)
  RETURN DATE
  DETERMINISTIC IS
  x_date   DATE;
BEGIN
  BEGIN
    x_date   := TO_DATE (p_string, p_format_mask);
    RETURN x_date;                                                        -- Only gets here if conversion was successful
  EXCEPTION
    WHEN OTHERS THEN
      RETURN p_error_date;
  END;
END safe_to_date;

Dann verwenden Sie es wie folgt:

WITH d AS
       (SELECT 'X' string_field FROM DUAL
        UNION ALL
        SELECT '11/15/2012' FROM DUAL
        UNION ALL
        SELECT '155' FROM DUAL)
SELECT safe_to_date (d.string_field, 'MM/DD/YYYY')
FROM   d;