打开游标:系统会在与这个会话相关的服务器进程的服务器端私有内存中为这个游标分配一个内存结构
,也就是用户全局区
解析游标:有一条sql语句与这个游标关联。解析后内容(包括执行计划)会被加载到共享池中的library cache
。UGA的结构会被更新,以保存指向这个共享游标在库缓存中的位置。
定义输出变量:如果sql语句返回数据,必须先定义接受数据的变量。这一点不仅对查询语句很重要
对于使用returing字句的delete、insert、和update语句也很重要。
绑定输入变量:如果sql语句使用了绑定变量,必须提供他们的值。绑定的过程是不做什么检查。如果指定了无效的数据,执行的过程
整会报出运行时错误。
执行游标:执行这个sql语句。
获取游标:如果sql语句返回数据,这一步会接收这些数据。特别是在查询语句中
大部分的处理工作都是在这一步进行的。在查询语句中,可能只会读取部分记录。换句话讲,
游标有可能在取到所有记录前被关闭。
关闭游标:释放uga中与这个游标有关的资源,从而这个资源可供其他游标使用。
在library cache中的共享游标不会被清除。它会继续保留在library cache中,等待被重新使用。
如下图

本文详细介绍了Oracle游标的处理过程,包括打开、解析、定义输出变量、绑定输入变量、执行、获取数据及关闭游标。解析过程中涉及VPD约束条件检查、语法与权限验证、逻辑优化和物理优化等步骤,确保SQL语句的有效执行。解析后的游标存储在库缓存中,以便重复使用。
最低0.47元/天 解锁文章
2116

被折叠的 条评论
为什么被折叠?



