如何使用 `execute immediate` 给变量赋值?
How to use `execute immediate` to assign a value to a variable?
我正在尝试使用 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语句)立即执行,你需要将其包装在开始 ... 结束;
此外,您不能从其中分配给立即执行块之外的变量,因此在您的示例中,尝试直接分配给 lv_kyc_main_GBL.legal_name 是行不通的。您需要为此使用绑定变量。我认为像下面这样的东西会起作用(我现在这里没有 Oracle 运行ning):
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;
我正在尝试使用 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语句)立即执行,你需要将其包装在开始 ... 结束;
此外,您不能从其中分配给立即执行块之外的变量,因此在您的示例中,尝试直接分配给 lv_kyc_main_GBL.legal_name 是行不通的。您需要为此使用绑定变量。我认为像下面这样的东西会起作用(我现在这里没有 Oracle 运行ning):
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;