首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用“立即执行”为变量赋值?

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

Stack Overflow用户
提问于 2016-02-11 12:19:45
回答 1查看 4.5K关注 0票数 1

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

代码语言:javascript
复制
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;
/

我得到的例外是:

代码语言:javascript
复制
anonymous block completed
lv_kyc_main_GBL.legal_name := 'TEST'

从命令第4行开始的错误:

代码语言:javascript
复制
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'

我不明白下面的作业有什么不对。如果我按以下方式单独执行任务,效果就会很好:

代码语言:javascript
复制
lv_kyc_main_GBL.legal_name := 'TEST'
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-02-11 12:40:06

我不太确定您要实现什么,但是要在立即执行中运行一个PLSQL块(而不是SQL语句),您需要在开始时包装它.结束;

此外,您不能从执行立即块内将变量赋值给它之外的变量,因此在您的示例中,试图直接分配给lv_kyc_main_GBL.legal_name将无法工作。为此,您需要使用绑定变量。我认为下面这样的内容会有效(我现在这里没有Oracle运行):

代码语言:javascript
复制
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;
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35339213

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档