问题描述
create or replace function f_myfunc(sqlstr varchar2) is pragma autonomous_transaction; Result varchar2(2000);begin --sqlstr类似于 'insert into mytable (field1, field2) values ('1', '2')' ; -- insert into mytable (field1, field2) values ('1', '2') returning rowid into Result; 这样是可以得到rowid的 execute immediate sqlstr ; --如何将rowid插入到tmp_mytmp中? insert into tmp_mytmp values(??); commit;end f_myfunc;调用这个过程时select f_myfunc ('insert into mytable (field1, field2) values ('1', '2')') from dual;select * from tmp_mytmp 希望能查到那个rowid.请问如何实现? 问题补充:Rainbow702 写道
解决方案
引用这么做,运行 是会报语法错的呀.(ORA-00905: 缺失关键字). 我机上没有装ORACLE,但是我是模仿你写的来给你个建议,它报哪里错呢?还有,你可以确定引用sqlstr := sqlstr || 'returning rowid into Result'; 执行完之后,新生成的记录的ID被存进了Result 了么?
解决方案二:
我的意思是这个create or replace function f_myfunc(sqlstr varchar2) return varchar2 as pragma autonomous_transaction; Result varchar2(2000); begin sqlstr := sqlstr || 'returning rowid into Result'; execute immediate Result; sqlstr := 'insert into tmp_mytmp values(' || Result || ')'; execute immediate Result; commit; return '1'; end f_myfunc;
解决方案三:
引用execute immediate Result;你这个执行完之后,没有再执行引用Result := 'insert into tmp_mytmp values(' + ID+ ')'; execute immediate Result;上面的 ID 就是你引用Result := 'insert into tmp_mytmp values('||sqlstr||')'; 执行产生的返回值啊。
解决方案四:
引用--如何将rowid插入到tmp_mytmp中? insert into tmp_mytmp values(??);你可以模仿这个引用insert into mytable (field1, field2) values ('1', '2')' ;sqlstr = 'insert into tmp_mytmp values(' + Result + ')';execute immediate sqlstr ;