函数 oracle 到 postgresql

function oracle to postgresql

我正在将 Oracle 数据库迁移到 PostgreSQL,以传输我没有问题的表,但是我在将它的函数转录到 Postgres 中的 运行 时遇到了问题,在 Oracle 中找到的函数下面:

create or replace FUNCTION  "FN_HOUR_MINUTE" (P_HOUR IN NUMBER) 
RETURN NUMBER 
IS
  -- PL/SQL Specification
  V_RETORN                 NUMBER(4);
  -- Convert hour to minute
  -- PL/SQL Block
BEGIN
V_RETORN := 60*TO_NUMBER(SUBSTR(LTRIM(TO_CHAR(P_HOUR,'0000'),' ') ,1,2))+
                  TO_NUMBER(SUBSTR(LTRIM(TO_CHAR(P_HOUR, '0000'),' '), 3,2));

RETURN V_RETORN;
EXCEPTION
WHEN OTHERS THEN
       RETURN NULL ;
END;

我尝试在 postgres 中编写如下:

CREATE OR REPLACE FUNCTION fn_hour_minute(p_hour in NUMERIC)
  RETURNS NUMERIC(4) AS $$
DECLARE
  v_retorn NUMERIC(4);
BEGIN
  v_retorn := 60*TO_NUMBER(SUBSTR(LTRIM(TO_CHAR(p_hour,'0000'),' ') ,1,2))+
                   TO_NUMBER(SUBSTR(LTRIM(TO_CHAR(p_hour, '0000'),' '), 3,2));
  RETURN v_retorn;
END;
$$ LANGUAGE plpgsql;

但是报错说 to_number 函数不存在。

您忘记包含 TO_NUMBER 部分的格式。将 TO_NUMBER 更新为 TO_NUMBER(SUBSTR(LTRIM(TO_CHAR(p_hour,'0000'),' ') ,1,2), '0000'),它应该可以工作。

如果将表达式展开为因子:

select TO_CHAR(1234,'0000'),
    ltrim(TO_CHAR(1234,'0000')),
    substr(ltrim(TO_CHAR(1234,'0000')),1,2),
    substr(ltrim(TO_CHAR(1234,'0000')),3,2)
from dual;

TO_CH LTRIM SU SU
----- ----- -- --
 1234 1234  12 34

你会发现这只是计算这样一个表达式的一种非常高级的方法

60 * TRUNC( p_hour / 100 ) + p_hour % 100