首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >什么是PL/SQL中的游标对象

什么是PL/SQL中的游标对象
EN

Stack Overflow用户
提问于 2010-12-24 06:55:52
回答 2查看 3.1K关注 0票数 1

我理解PL/SQL变量的概念,但我无法在脑海中清楚地看到PL/SQL中的游标对象。

我在某个地方读过下面的文字,我觉得自己无法理解游标对象的概念。

“如果尚未将游标变量分配给任何游标对象,则OPEN语句将隐式地为该变量创建一个对象。

如果在打开时游标变量已经指向游标对象,则OPEN不创建新对象。相反,它重用现有的对象并向该对象附加一个新的查询。游标对象与游标或查询本身分开维护。“

请解释一下内部是如何工作的.

EN

回答 2

Stack Overflow用户

发布于 2010-12-24 07:02:59

您可以将它视为C编程语言中使用的指针(如果您曾经学过的话),它指向从SQL语句检索到的每一行数据。将光标移到下一行以读取下一行。

参考文献:http://www.cse.unsw.edu.au/~cs9311/10s2/lectures/week04/PL_SQL.pdf,这是我用来学习PL/SQL的讲义

票数 0
EN

Stack Overflow用户

发布于 2010-12-24 07:11:23

据我所知,光标就像指向结果集中一行的指针。在其他编程语言中,它类似于枚举数。枚举数是帮助遍历项集合的对象。

例如:

代码语言:javascript
运行
复制
declare
  cursor cur is select * from someTable;

begin
  open cur;
  loop
    fetch cur into record;
    exit when cur%notfound;
    dbms_output.put_line('Col1: ' || record.col1 || ', Col2: ' || record.col2);
  end loop;
end;

与C#中的类似:

代码语言:javascript
运行
复制
    string[] collection = new string[]{"A", "B", "C"};
    var enumerator = collection.GetEnumerator();
    while(enumerator.MoveNext())
    {
        Console.WriteLine("current item:" + enumerator.Current);
    }

注意,使用游标获取记录数据与使用枚举数获取数据类似。

希望这能帮到你。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4524743

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档