Oracle
 sql >> база данни >  >> RDS >> Oracle

Как да намеря конкретна маска в низ - Oracle?

Звучи като проблем с модела на данни (съхраняване на дата в низ).

Но тъй като се случва и понякога не можем да контролираме или променяме нещата, обикновено поддържам функция като тази:

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;

След това го използвайте по следния начин:

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;


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL Developer не показва XML

  2. Динамичен дял на таблицата Oracle

  3. Oracle RAC и последователности

  4. Oracle тригерен журнал

  5. Как да синхронизирам java метод, извикан от PL/SQL