функции от MS SQL до Oracle SQL - PullRequest
       29

функции от MS SQL до Oracle SQL

0 голосов
/ 10 февраля 2020

Есть ли способ использовать следующую функцию из MS SQL в Oracle SQL Developer

create function fnDays2NextEvent(@birthdate datetime, @today datetime)
returns integer
as
begin
   declare @birthday datetime
   set @birthday = @birthdate
   while @birthday < @today set @birthday = dateadd(yy, 1, @birthday)
   return datediff(dd,@today,@birthday)
end;

Ответы [ 3 ]

1 голос
/ 10 февраля 2020

Вам необходимо создать в Oracle функцию, аналогичную этой.

Как показано ниже:

CREATE OR REPLACE FUNCTION FNDAYS2NEXTEVENT (
    BIRTHDATE   IN          DATE,
    TODAY       IN          DATE
) RETURN INT AS
BEGIN
    RETURN BIRTHDATE 
           + CEIL(MONTHS_BETWEEN(TODAY, BIRTHDATE) / 12) 
                * INTERVAL '1' YEAR - TODAY + 1;
END;
/

Тогда вы сможете использовать ее.

SQL> SELECT FNDAYS2NEXTEVENT(DATE'1991-07-20',SYSDATE) FROM DUAL;

FNDAYS2NEXTEVENT(DATE'1991-07-20',SYSDATE)
------------------------------------------
                                       161

SQL> SELECT SYSDATE + 161 FROM DUAL;

SYSDATE+1
---------
20-JUL-20

SQL>

Я не знаю, требуется ли это вам, прокомментируйте в случае расхождения в ответе и ожидании.

Приветствия !!

0 голосов
/ 10 февраля 2020

Если вы ищете эквивалент oracle, попробуйте следующее:

create or replace function fnDays2NextEvent(birthdate date, today date)
return number
is
begin
return  trunc(birthdate)- trunc(today) ;
end fnDays2NextEvent;

test

select fnDays2NextEvent(to_date('02/14/2020','MM/DD/YYYY'),sysdate) from dual
0 голосов
/ 10 февраля 2020

функция может выглядеть следующим образом:

CREATE OR REPLACE function fnDays2NextEvent(birthdate DATE, today DATE)
returns NUMBER
AS
  v_bd DATE;
begin
   v_bd := birthdate;
   while v_bd < today 
   LOOP
      v_bd = ADD_MONTHS(v_bd,12);
   END LOOP;
   RETURN today - v_bd;
end;

этот код не оптимизирован и перевод 1: 1 из вашего кода

...