程序员人生 网站导航

[置顶] Oracle游标―for、loop、if结合应用

栏目:数据库应用时间:2015-05-04 10:21:55


1、需求


甚么时候会用到Oracle游标,和其中的for、loop、if呢?

先看这样1个需求:

有1张学生授课表T_TEACHING,每一个学生都有数门课程:

主键ID(自增)
课程号COURSE_ID
学号USER_ID
1
01
201501
2
02
201501
3
03
201501
4
01
201502
5
01
201503
6
01
201504
7
02
201504
...
...
...

但是由于某些缘由,致使有的学生课程不全(本应当每一个学生都有3门课),应当如何把不全的学生检索出来,再给这些学生添加课程呢,并且要求能够快速解决这个问题。


2、分析


我们对需求进行1步步梳理:

1、我们不知道哪一个学生课程不全,所以需要循环判断每一个学生

通经常使用for循环:for USER_ID in USER_IDS

2、循环判断每一个学生就要拿到所有的学号

select:select USER_ID from  T_TEACHING GROUP BY USER_ID;

3、有了学号,判断这个学生是不是缺少课程,然后添加这门课

(1)select:select count(*) from T_TEACHING where USER_ID=@USER_ID and COURSE_ID=@COURSE_ID;

(2)if else 判断

(3)insert:insert into T_TEACHING(COURSE_ID,USER_ID) values (@COURSE_ID,@USER_ID)

通过分析大致的流程出来了,然后再看细节:

我们通过select ..GROUP BY获得了授课表中所有的学号,然后就对这些学号进行循环获得,关键在于select ..GROUP BY出来如何循环获得。


3、方法


在oracle中提供了“游标”

  游标是甚么,游标用来处理从数据库中检索的多行记录(使用SELECT语句)。利用游标,程序可以逐一地处理和遍历1次检索返回的全部记录集。

这正是我们想要的!!

结合for循环,我们可使用for循环游标,格式以下:

--(1)定义游标 --关键字cursor cursor x is select语句  --(2)定义游标变量   y x%rowtype --(3)使用for循环来使用这个游标 for y in x loop --逻辑处理 end loop;

下面我们通过sql存储进程来完全的实现上面的需求

declare --定义类型  cursor t_tea is select USER_ID from T_TEACHING GROUP BY USER_ID; --定义1个游标变量  t_row t_tea%rowtype; --定义1个number类型的临时变量     v_count number; begin for t_row in t_tea loop     select count(*) into v_count from T_TEACHING where USER_ID=t_row.USER_ID and COURSE_ID=02;      if v_count = 0 then        insert into T_TEACHING(COURSE_ID,USER_ID) values (02,t_row.USER_ID);      end if;        end loop; end;



4、总结

  

  oracle中的游标循环不只有for循环,oracle中提供了两种游标,显示游标和隐式游标,其他游标的使用方式可以在这里了解,用到了在深入研究:http://www.cnblogs.com/sc-xx/archive/2011/12/03/2275084.html




------分隔线----------------------------
------分隔线----------------------------

最新技术推荐