vishare 2011-08-31 15:28
浏览 542
已采纳

在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条回答 默认 最新

  • rainbow702 2011-08-31 16:24
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 Qt下使用tcp获取数据的详细操作
  • ¥15 idea右下角设置编码是灰色的
  • ¥15 全志H618ROM新增分区
  • ¥20 jupyter保存图像功能的实现
  • ¥15 在grasshopper里DrawViewportWires更改预览后,禁用电池仍然显示
  • ¥15 NAO机器人的录音程序保存问题
  • ¥15 C#读写EXCEL文件,不同编译
  • ¥15 MapReduce结果输出到HBase,一直连接不上MySQL
  • ¥15 扩散模型sd.webui使用时报错“Nonetype”
  • ¥15 stm32流水灯+呼吸灯+外部中断按键