0

在我将这个请求注入我的 Talend 项目之前,我正在使用 Oracle SQL Developer 测试我的数据库请求。

这是一个例子。我有一个在 SQL Developer 工具上运行良好但在我的 Talend 项目上运行良好的请求。

我的 sql 语句有一个函数声明,然后是这样的选择:

create or replace function updateDate(p_date varchar2) return date as
  l_date date;
  e_bad_day exception;
  pragma exception_init (e_bad_day, -1847);
begin
  begin
    -- try to convert
    l_date := to_date(p_date,'yyyymmdd');
  exception
    when e_bad_day then
      -- ignore the supplied day value and get last day of month
      l_date := last_day(to_date(substr(p_date, 1, 6), 'yyyymm'));
  end;
  return l_date;
end;
/
Select ASRF_NUMASR NIR,
ASSUR_NOASSURE NOASSURE,
ASRF_CODSEX sexe,
updateDate(ASSUR_DATNAIS) as DATE_REAL
from NORMAL_ASSUR 
UNION
Select ASRF_NUMASR NIR,
ASSUR_NOASSURE NOASSURE,

当我在我的 Talend 项目上放置相同的文本时,它不起作用。它似乎只执行我的函数声明。

例外是:

ORA-01003 aucune instruction analysé
4

1 回答 1

2

虽然我不建议在每次执行作业时使用 Talend 创建/替换 updateDate 函数,因为最好在您的 sql 开发人员中预先创建它,您可以尝试使用 2 个组件分隔您的 sql 脚本:

脚本的 DDL 部分位于tOracleRow

"create or replace function updateDate(p_date varchar2) return date as
  l_date date;
  e_bad_day exception;
  pragma exception_init (e_bad_day, -1847);
begin
  begin
    -- try to convert
    l_date := to_date(p_date,'yyyymmdd');
  exception
    when e_bad_day then
      -- ignore the supplied day value and get last day of month
      l_date := last_day(to_date(substr(p_date, 1, 6), 'yyyymm'));
  end;
  return l_date;
end;"

DML 部分进入tOracleInput(并在组件上设置相应的模式)

"Select ASRF_NUMASR NIR,
ASSUR_NOASSURE NOASSURE,
ASRF_CODSEX sexe,
updateDate(ASSUR_DATNAIS) as DATE_REAL
from NORMAL_ASSUR 
UNION
Select ASRF_NUMASR NIR,
ASSUR_NOASSURE NOASSURE,
..."

并这样称呼他们:

tOracleRow
   |
OnSubjobOk
   |
tOracleInput -- Main -- target
于 2018-02-12T14:25:36.743 回答