gpt4 book ai didi

oracle - PL/SQL : Best practice for fetching 2 or more joined tables from a cursor?

转载 作者:行者123 更新时间:2023-12-01 15:30:10 25 4
gpt4 key购买 nike

我听说使用 %ROWTYPE 属性在 PL/SQL 中定义记录是一种很好的做法。这样可以节省键入时间,并允许您的包即使在添加或删除列时也能继续运行。 (如果我错了请纠正我!)

但是,当我从涉及连接的游标中提取数据时,我发现我必须提取到程序员定义的记录中,该记录包括连接返回的每一列的(相当长的)手写列表.

所以我的问题是:是否有可能提取到嵌套记录中,或者提取到记录列表中,或者做某事来避免这种丑陋的困惑?我尝试过的所有操作都会导致有关记录与游标返回的内容不匹配的错误。

使用游标返回连接结果对我来说似乎是一个常见的用例,奇怪的是在搜索中没有出现与此相关的任何内容。

谢谢。

最佳答案

您可以使用 cursor%rowtype。

示例:

declare
cursor c_c is
select emp.*, dept.* -- use aliasses if columns have same name
from emp
, dept; -- for sample no join condition

r_c c_c%rowtype;

begin
for r_c in c_c loop -- with for loop even the definition of r_c is not needed.
...
end loop;
end;
/

关于oracle - PL/SQL : Best practice for fetching 2 or more joined tables from a cursor?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/589253/

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