前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Oracle的静态游标与动态游标

Oracle的静态游标与动态游标

作者头像
Vaccae
发布2019-07-24 10:59:51
2.9K0
发布2019-07-24 10:59:51
举报
文章被收录于专栏:微卡智享

前言

我们在写Oracle的存储过程里面,经常会用到游标,Oracle里面的游标分为静态游标和动态游标。今天我们在说一下分别有什么不同。

静态游标和动态游标的概念

静态游标

显式游标和隐式游标称为静态游标,因为在使用他们之前,游标的定义已经完成,不能再更改。

定义:

Cursor 游标名(参数1,参数2......) is 查询语句

调用时:

for 变量行 in 游标名 loop

end loop;

动态游标

游标在声明时没有设定,在打开时可以对其进行修改。

定义:

TYPE 游标别名 IS REF CURSOR;

游标名 游标别名;

调用时:

open 游标名 for 动态SQL语句;

loop

exit when 游标名%NOTFOUND;

fetch 游标名

into 变量1,变量2,变量3,变量4;

相对来说静态游标在存储过程中用到的会比较多,而动态游标相对较少,像我们如果存在分割表的时候,取数据时就会用到动态游标了。

代码演示

使用背景

我们在存储过程中输入开始和结束日期,用于查询开始到结束日期这一段时间内的销售。

解决思路

这个查询我们就可以用到静态游标和动态游标的结合使用。

  1. 通过静态游标设置开始和结果日期获取到所涉及到的当前年月。
  2. 根据获取到的当前年月生成要查询对应的月份分割表的动态SQL语句。
  3. 用动态游标遍历,然后进行数据的处理。

代码

上面是定义和静态游标和动态游标,下面的静态游标的写法,是根据输入的开始和结束日期获取对应的当前年月

即如果输入了2018-06-01----2018-08-30

游标显示结果为

201806

201807

201808


根据输入的日期通过静态游标生成对应的动态SQL语句。vs_sSql是我们的动态字符串,把主表查询先加进来,然后根据输入的开始和结束日期找到对应的月份分割表,然后判断表是否存在,如果存在的话就用union all把分割表加入到动态SQL语句里


通过动态sql语句使用动态游标遍历销售进行数据的更新。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-08-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 微卡智享 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档