gpt4 book ai didi

sql - 在 oracle 过程中如何获取刚刚添加的 PKId 作为 FK ID 添加到下一个表

转载 作者:行者123 更新时间:2023-12-02 06:15:47 27 4
gpt4 key购买 nike

在一个oracle程序中,我需要在EmployeeHeader表中插入数据,然后插入这个表的PK id作为EmployeeDetails表的FK id。我们怎样才能做到这一点?

 INSERT INTO EmployeeHeader(
HEADER_PK_ID
empNo

)
VALUES(
HEADER_PK_ID_SEQ.NEXTVAL,
'SOMETHING'

);

INSERT INTO EmployeeDetails (
DTLHEADER_PK_ID,
HEADER_fK_ID
empname,
age

)
VALUES(
DTLHEADER_PK_ID_SEQ.NEXTVAL,
HEADER_PK_IDn, -- (THIS NEEDS TO BE FETCHED FROM EmployeeHeader)
21
);

最佳答案

在大多数情况下你可以使用currval:

select HEADER_PK_ID_SEQ.CURRVAL
from dual;

如果您希望值对于并发插入是安全的,您可能需要将两个插入包装在一个事务中。

关于sql - 在 oracle 过程中如何获取刚刚添加的 PKId 作为 FK ID 添加到下一个表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32991038/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com