如何使用“立即执行”为变量赋值



我试图将execute immediate用作分配变量值的特殊要求。我正在使用以下代码并得到如下异常。

declare
  lv_kyc_main_GBL KYC_GBL_MAIN.KYC_MAIN%rowtype;
  l_str varchar2(400);
  a number(10);
begin
  select *
    into lv_kyc_main_GBL
    from KYC_GBL_MAIN.KYC_MAIN
   where rownum = 1;
  -- l_str:='lv_kyc_main_GBL.legal_name'||':='||'''TEST''';
  l_str := 'lv_kyc_main_GBL.legal_name := ''TEST''';
  dbms_output.put_line(l_str);
  execute immediate (l_str);
end;
/

我得到的例外是:

anonymous block completed
lv_kyc_main_GBL.legal_name := 'TEST'

命令中从第 4 行开始出错:

declare
  lv_kyc_main_GBL KYC_GBL_MAIN.KYC_MAIN%rowtype;
  l_str varchar2(400);
  a number(10);
begin
  select *
    into lv_kyc_main_GBL
    from KYC_GBL_MAIN.KYC_MAIN
   where rownum = 1;
  --l_str:='lv_kyc_main_GBL.legal_name'||':='||'''TEST''';
  l_str := 'lv_kyc_main_GBL.legal_name := ''TEST''';
  dbms_output.put_line(l_str);
  execute immediate (l_str);
end;
/
Error report:
ORA-00900: invalid SQL statement
ORA-06512: at line 14
00900. 00000 -  "invalid SQL statement"
*Cause:    
*Action:
lv_kyc_main_GBL.legal_name := 'TEST'

我不明白下面的作业有什么问题。如果我单独执行作业,它就可以正常工作:

lv_kyc_main_GBL.legal_name := 'TEST'

我不太确定您要实现什么,但是要立即执行PLSQL块(即不是SQL语句(,您需要将其包装在begin中...结束;

此外,您不能从执行即时块外部将其分配给变量,因此在您的示例中,尝试直接分配给 lv_kyc_main_GBL.legal_name 将不起作用。为此,您需要使用绑定变量。 我认为类似以下内容的东西会起作用(我现在没有在这里运行 Oracle(:

declare
  lv_kyc_main_GBL KYC_GBL_MAIN.KYC_MAIN%rowtype;
  l_str varchar2(400);
  a number(10);
begin
 select * into lv_kyc_main_GBL
 from KYC_GBL_MAIN.KYC_MAIN where rownum=1;
 l_str := 'begin :b1 := ''TEST''; end';
 dbms_output.put_line(l_str);
 execute immediate (l_str) using out lv_kyc_main_GBL.legal_name;
end;

相关内容

  • 没有找到相关文章

最新更新