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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于游标的记录与强引用游标相关的知识,希望对你有一定的参考价值。

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

答案

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

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

这里有些例子:

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;
/

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

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

Oracle_PL/SQL 游标

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

For循环不打印游标中的最后一条记录

SQL记录-PLSQL游标

oracle中游标的使用?