0

我正在创建一个接受两个参数的函数。我的参数之一将用作我的语句的数据库链接。我试过连接它。我将如何实现这一目标?

它显示了这个错误

ORA-00923:在“NOINK.CHECK_SECOND_REF_DIE”第 13 行的预期 ORA-06512 处未找到 FROM 关键字。

下面是代码。

drop function check_second_ref_die;

create or replace function check_second_ref_die(lotNumber in VARCHAR2, db_link in VARCHAR2)
    return varchar2
is

    row_count NUMBER; 
    sql_statement VARCHAR2(300);


BEGIN 
    sql_statement := 'SELECT COUNT(*) FROM wcrepo.WCR_WAFER_REFERENCE@lepftds.itg.ti.com 
    WHERE waferconfigfile = (SELECT waferconfigfile FROM program_setup_rev@' || db_link ||
    'WHERE device = (SELECT device FROM noink.lot WHERE lot_num = ' ||lotNumber || ') 
    AND setup_cnt=0) AND status =' || 'Approved' || 'AND ref_die_type =' || 'Secondary';

    execute immediate sql_statement into row_count;

    IF (row_count != 0) THEN
        RETURN 'TRUE';
    ELSE
        RETURN'FALSE';
    END IF;

  END;

这是我尝试调用函数时的代码

SELECT CASE
           WHEN check_second_ref_die ('8019572', 'rfabtwdb.dal.make.ti.com') = 'TRUE'
           THEN 'EXISTS' ELSE 'NOT EXISTS'
       END
           AS RESULT
  FROM DUAL
4

1 回答 1

1

AND status =' || 'Approved' || 'AND

这是错误的。删除连接运算符,我们有......

AND status =ApprovedAND 

...这不是有效的 SQL。要引用字符串文字,您需要转义单引号。最简单的方法是使用其中两个:

AND status =''Approved'' AND

您需要修复代码中的所有字符串文字。

动态 SQL 很难,因为它会将编译错误转化为运行时错误。通过包含一些简单的检测,您可以更轻松地调试代码。如果您的代码在 EXECUTE IMMEDIATE 之前有这一行,您可能已经看到了执行的语句,并且可能自己发现了大器。

dbms_output.put_line(v_sql);
于 2019-04-04T06:28:59.757 回答