基于游标的记录与强引用游标

Posted

技术标签:

【中文标题】基于游标的记录与强引用游标【英文标题】:Cursor Based Record vs Strong ref cursor 【发布时间】:2018-12-29 15:57:07 【问题描述】:

我是 Oracle 数据库和 pl/sql 语言的新手。我的问题是强引用游标和基于游标的记录之间有什么区别 - 例如“var_exmpl”变量将存储游标值,即“cur_exmpl%rowtype”

【问题讨论】:

【参考方案1】:

您使用 ref 游标类型来声明游标变量。然后,您可以像使用显式游标一样从这些游标变量中获取。在这两种情况下,您都可以并且通常会提取到记录中。

使用显式游标,您可以根据游标声明记录。使用强引用游标类型,我将声明基于用于声明引用游标的相同类型的记录。

这里有一些例子:

DECLARE
   TYPE employee_rt IS RECORD
   (
      employee_id   employees.employee_id%TYPE,
      salary        employees.salary%TYPE
   );

   TYPE strong_rc IS REF CURSOR
      RETURN employee_rt;

   strong_rec              employee_rt;

   CURSOR twocols_cur
   IS
      SELECT employee_id, salary FROM employees;

   rec_from_explicit_cur   twocols_cur%ROWTYPE;
BEGIN
   OPEN strong_rc FOR SELECT employee_id, salary FROM employees;

   FETCH strong_rc INTO strong_rec;

   CLOSE strong_rc;

   OPEN twocols_cur;

   FETCH twocols_cur INTO rec_from_explicit_cur;

   CLOSE twocols_cur;
END;
/

【讨论】:

所以在这两种情况下,我们使用不同的游标得到相同的结果。它们之间没有区别,那么哪个性能更好? 在性能方面没有差异。通常,当您需要 (a) 更改要在运行时执行的查询时,您可以使用游标变量 - 您可以打开动态查询(字符串)或带有 case 或 If 的不同静态查询,或者 (b) 您需要将游标变量传递到另一个块或传递到非 PL/SQL 上下文,如 Java 程序。

以上是关于基于游标的记录与强引用游标的主要内容,如果未能解决你的问题,请参考以下文章

弱符号与强符号,弱引用与强引用

PL/SQL 在游标中引用另一个游标?

如何优化流水线、弱类型引用游标的使用

Oracle_PL/SQL 游标

是否有可能根据动态打开的引用游标的输出创建视图或表?

REF CURSOR 总结