oracle 游标处理过程

打开游标:系统会在与这个会话相关的服务器进程的服务器端私有内存中为这个游标分配一个内存结构

,也就是用户全局区

解析游标:有一条sql语句与这个游标关联。解析后内容(包括执行计划)会被加载到共享池中的library cache

。UGA的结构会被更新,以保存指向这个共享游标在库缓存中的位置。

定义输出变量:如果sql语句返回数据,必须先定义接受数据的变量。这一点不仅对查询语句很重要

对于使用returing字句的delete、insert、和update语句也很重要。

绑定输入变量:如果sql语句使用了绑定变量,必须提供他们的值。绑定的过程是不做什么检查。如果指定了无效的数据,执行的过程

整会报出运行时错误。

执行游标:执行这个sql语句。

获取游标:如果sql语句返回数据,这一步会接收这些数据。特别是在查询语句中

大部分的处理工作都是在这一步进行的。在查询语句中,可能只会读取部分记录。换句话讲,

游标有可能在取到所有记录前被关闭。

关闭游标:释放uga中与这个游标有关的资源,从而这个资源可供其他游标使用。

在library cache中的共享游标不会被清除。它会继续保留在library cache中,等待被重新使用。

如下图


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值