I am trying to use execute immediate
as a special requirement for assigning the value of a variable. I am using the following code and getting the exception as below.
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;
/
The exception I'm getting is:
anonymous block completed
lv_kyc_main_GBL.legal_name := 'TEST'
Error starting at line 4 in command:
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'
I can't understand what is wrong in the following assignment. It just works fine if I do the assignment separately as:
lv_kyc_main_GBL.legal_name := 'TEST'