在oracle中如何实现,一个function将传入的insert语句的rowid插入到临时表.

[code="java"]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;[/code]

调用这个过程时
select f_myfunc ('insert into mytable (field1, field2) values ('1', '2')') from dual;
select * from tmp_mytmp 希望能查到那个rowid.

请问如何实现?

4个回答

[quote]这么做,运行 是会报语法错的呀.(ORA-00905: 缺失关键字). [/quote]我机上没有装ORACLE,但是我是模仿你写的来给你个建议,它报哪里错呢?
还有,你可以确定[quote]sqlstr := sqlstr || 'returning rowid into Result'; [/quote]执行完之后,新生成的记录的ID被存进了Result 了么?

[quote]
--如何将rowid插入到tmp_mytmp中?

insert into tmp_mytmp values(??);
[/quote]
你可以模仿这个[quote]insert into mytable (field1, field2) values ('1', '2')' ;[/quote]
[code="sql"]
sqlstr = 'insert into tmp_mytmp values(' + Result + ')';
execute immediate sqlstr ;

[/code]

[quote]execute immediate Result;[/quote]
你这个执行完之后,没有再执行
[quote]
Result := 'insert into tmp_mytmp values(' + ID+ ')';

execute immediate Result;
[/quote]
上面的 ID 就是你[quote]Result := 'insert into tmp_mytmp values('||sqlstr||')'; [/quote]执行产生的返回值啊。

我的意思是这个
[code="sql"]
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;
[/code]

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐