sql >> Database teknologi >  >> RDS >> Oracle

Oracle svarende til SQL Server/Sybase DateDiff

Jeg stjal det meste af dette fra en gammel tom-artikel for et par år siden, rettede nogle fejl fra artiklen og ryddede op i den. Afgrænsningslinjerne for datediff beregnes forskelligt mellem oracle og MSSQL, så du skal være forsigtig med nogle eksempler, der flyder rundt derude, som ikke korrekt tager højde for MSSQL/Sybase-stilgrænser, som ikke giver brøkdele resultater.

Med følgende skulle du være i stand til at bruge MSSQL-syntaks og få de samme resultater som MSSQL, såsom SELECT DATEDIFF(dd,getdate(),DATEADD(dd,5,getdate())) FROM DUAL;

Jeg påstår kun, at det virker - ikke at det er effektivt eller den bedste måde at gøre det på. Jeg er ikke en Oracle-person :) Og du vil måske overveje to gange om at bruge mine funktionsmakroer til at omgå, at jeg skal bruge anførselstegn omkring dd,mm,hh,mi..osv.

(opdatering af Mark Harrison) tilføjet dy-funktion som alias for 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. Docker:Kombiner flere billeder

  2. MySQL-forbindelse virker ikke:2002 Ingen sådan fil eller mappe

  3. Er der en måde at slette en række fra mysql efter en vis tid fra indsættelsestidspunktet

  4. Oracle ODP.Net og EF CodeFirst - SaveChanges-fejl