如何使用`execute immediate`为变量赋值?

时间:2016-02-11 12:19:45

标签: oracle plsql dynamic-sql execute-immediate

我正在尝试使用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'

1 个答案:

答案 0 :(得分:5)

我不确定你要实现的是什么,但是要在执行立即执行PLSQL块(即不是SQL语句),你需要将它包装在begin ... end;

此外,您无法从其中分配执行立即数块之外的变量,因此在您的示例中,尝试直接分配给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;