简体   繁体   English

从 MSSQL 到 Oracle SQL 的函数

[英]functions from MSSQL to Oracle SQL

Is there a way to use the following function from MSSQL in Oracle SQL Developer有没有办法在 Oracle SQL Developer 中使用 MSSQL 中的以下函数

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;

You need to create the function in Oracle similar to this one.您需要在 Oracle 中创建与此类似的函数。

Like the following:像下面这样:

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;
/

Then, You will be able to use it.然后,您将能够使用它。

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>

I don't know if this is what you require, Do comment in case of any discrepancy in the answer and expectation.我不知道这是否是您的要求,如果答案和期望有任何差异,请发表评论。

Cheers!!干杯!!

the function could look like:该函数可能如下所示:

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;

this code is not optimized and is 1 to 1 migration from your code此代码未优化,是从您的代码 1 对 1 迁移

If you are looking for the oracle equivalent, then try this:如果您正在寻找等效的 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

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM