Adi*_*man 0 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;
/
Run Code Online (Sandbox Code Playgroud)
我得到的例外是:
anonymous block completed
lv_kyc_main_GBL.legal_name := 'TEST'
Run Code Online (Sandbox Code Playgroud)
在命令的第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'
Run Code Online (Sandbox Code Playgroud)
我无法理解以下任务中的错误.如果我单独进行分配,它就可以正常工作:
lv_kyc_main_GBL.legal_name := 'TEST'
Run Code Online (Sandbox Code Playgroud)
我不确定你想要实现什么,但是要在执行立即执行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;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2291 次 |
| 最近记录: |