使用Oracle存储过程在多个表中插入数据

ABC*_*ABC 5 .net c# oracle stored-procedures

我有 4 个表,table1、table2、table3 和 table4,它们是相互关联的。Table1 将生成一个主键,该主键将在其余表中用作参考键。

我必须使用这个主键在表 4 中插入多条记录。由于要求是事务要么成功提交,要么回滚所有更改。这就是我想到在存储过程中编写它的原因。但是当我不得不为 table4 传递多行数据时卡住了。

任何人都可以请建议,我怎样才能做到这一点?

提前致谢。

Sag*_*tri 2

我猜你想做这样的事情

CREATE OR REPLACE PROCEDURE myproc
(
 invId IN NUMBER,
 cusId IN NUMBER
)
IS
    temp_id  NUMBER; 
BEGIN 
    INSERT INTO myTable (INV_ID) 
    VALUES (invId)
    returning id into temp_id;

    INSERT INTO anotherTable (ID, custID) 
    VALUES (temp_id, custId);  
END myproc;
Run Code Online (Sandbox Code Playgroud)