Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Oracle odpowiednik SQL Server/Sybase DateDiff

Ukradłem większość tego ze starego artykułu o tomie kilka lat temu, naprawiłem kilka błędów w artykule i posprzątałem. Linie rozgraniczające dla datediff są obliczane inaczej między Oracle i MSSQL, więc musisz uważać na niektóre przykłady krążące wokół, które nie uwzględniają prawidłowo granic stylu MSSQL/Sybase, które nie dostarczają wyników ułamkowych.

Dzięki następującym zasadom powinieneś być w stanie używać składni MSSQL i uzyskać takie same wyniki jak MSSQL, takie jak SELECT DATEDIFF(dd,getdate(),DATEADD(dd,5,getdate())) FROM DUAL;

Twierdzę tylko, że to działa, a nie, że jest skuteczny lub najlepszy sposób, aby to zrobić. Nie jestem osobą od Oracle :) A może warto pomyśleć dwa razy o używaniu moich makr funkcyjnych do obejścia cudzysłowów wokół dd,mm,hh,mi...itd.

(aktualizacja Marka Harrisona) dodano funkcję dy jako alias dla dd.

CREATE OR REPLACE FUNCTION GetDate 
RETURN date IS today date;
BEGIN
RETURN(sysdate);
END;
/

CREATE OR REPLACE FUNCTION mm RETURN VARCHAR2 IS BEGIN RETURN('mm'); END;
/
CREATE OR REPLACE FUNCTION yy RETURN VARCHAR2 IS BEGIN RETURN('yyyy'); END;
/
CREATE OR REPLACE FUNCTION dd RETURN VARCHAR2 IS BEGIN RETURN('dd'); END;
/
CREATE OR REPLACE FUNCTION dy RETURN VARCHAR2 IS BEGIN RETURN('dd'); END;
/
CREATE OR REPLACE FUNCTION hh RETURN VARCHAR2 IS BEGIN RETURN('hh'); END;
/
CREATE OR REPLACE FUNCTION mi RETURN VARCHAR2 IS BEGIN RETURN('mi'); END;
/
CREATE OR REPLACE FUNCTION ss RETURN VARCHAR2 IS BEGIN RETURN('ss'); END;
/

CREATE OR REPLACE Function DateAdd(date_type IN varchar2, offset IN integer, date_in IN date )
RETURN date IS date_returned date;
BEGIN
date_returned := CASE date_type
    WHEN 'mm'   THEN add_months(date_in,TRUNC(offset))
    WHEN 'yyyy' THEN add_months(date_in,TRUNC(offset) * 12)
    WHEN 'dd'   THEN date_in + TRUNC(offset)
    WHEN 'hh'   THEN date_in + (TRUNC(offset) / 24)
    WHEN 'mi'   THEN date_in + (TRUNC(offset) /24/60)
    WHEN 'ss'   THEN date_in + (TRUNC(offset) /24/60/60)
    END;
RETURN(date_returned);
END;
/

CREATE OR REPLACE Function DateDiff( return_type IN varchar2, date_1 IN date, date_2 IN date)
RETURN integer IS number_return integer;
BEGIN
number_return := CASE return_type
    WHEN 'mm'   THEN ROUND(MONTHS_BETWEEN(TRUNC(date_2,'MM'),TRUNC(date_1, 'MM')))
    WHEN 'yyyy' THEN ROUND(MONTHS_BETWEEN(TRUNC(date_2,'YYYY'), TRUNC(date_1, 'YYYY')))/12
    WHEN 'dd'   THEN ROUND((TRUNC(date_2,'DD') - TRUNC(date_1, 'DD')))
    WHEN 'hh'   THEN (TRUNC(date_2,'HH') - TRUNC(date_1,'HH')) * 24
    WHEN 'mi'   THEN (TRUNC(date_2,'MI') - TRUNC(date_1,'MI')) * 24 * 60
    WHEN 'ss'   THEN (date_2 - date_1) * 24 * 60 * 60
    END;
RETURN(number_return);
END;
/


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jak dodać jeden do sznurka w Oracle?

  2. java.sql.SQLException:Wyjątek we/wy:Karta sieciowa nie może nawiązać połączenia?

  3. Baza danych:funkcje potokowe

  4. kolumna nie jest null odroczona

  5. Oracle XMLTable — pobieranie kolumny z węzła nadrzędnego