我正在创建一个接受两个参数的函数。我的参数之一将用作我的语句的数据库链接。我尝试将其串联。我将如何实现这一目标?
它显示此错误
ORA-00923:在预期的ORA-06512处找不到FROM关键字 “ NOINK.CHECK_SECOND_REF_DIE”,第13行。
下面是代码。
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
答案 0 :(得分:1)
AND status =' || 'Approved' || 'AND
这是错误的。删除串联运算符,我们可以...
AND status =ApprovedAND
...这是无效的SQL。要引用字符串文字,您需要转义单引号。最简单的方法是使用其中两个:
AND status =''Approved'' AND
您需要修复代码中的所有字符串文字。
动态SQL很难,因为它将编译错误转换为运行时错误。通过包含一些简单的工具,可以使调试代码变得更加容易。如果您的代码在EXECUTE IMMEDIATE之前有此行,则您可能已经看到了执行的语句,并可能为自己找到了Bloomer。
dbms_output.put_line(v_sql);