zoukankan      html  css  js  c++  java
  • 游标的原理

     
     
        一般情况下,SQL查询结果都是多条纪录的结果集,而高级语言一次只能处理一条纪录,用游标机制,将多条纪录一次一条读取出来处理。从而把对集合的操作转化为对单个纪录的处理。游标使用的步骤如下:
    1、说明游标。说明游标的时候并不执行select语句。
     declare <游标名> cursor for <select语句>;
     
    2、打开游标。打开游标实际上是执行相应的select语句,把查询结果读取到缓冲区中。这时候游标处于活动状态,指针指向查询结果集的第一条纪录。
     open <游标名>;
     
    3、推进游标指针并读取当前纪录。用fetch语句把游标指针向前推进一条纪录,同时将缓冲区中的当前纪录读取出来送到变量中。fetch语句通常用在一个循环结构体中,通过循环执行fetch语句逐条取出结果集中的行进行处理。现在好多数据库中,还允许任意方向任意步长易懂游标指针,而不仅仅是把游标指针向前推进一行了。
     fetch <游标名> into <变量1>,<变量2>...
     
    4、关闭游标。用close语句关闭游标,释放结果集占用的缓冲区及其他资源。游标关闭后,就不再和原来的查询结果集相联系。但游标可以再次打开,与新的查询结果相联系。
     close <游标名>;
    //以上出处摘至网络,忘记出处了。。。。。
     
     
     
    //在传统的数据库概论第四版,存储过程有一道这样的题目,自己做完拿出来给大家参考一下

      在Course表中增加一门课程,若已存在该课程即退出;若不存在即为某个指定系的学生增加选修这门课程,返回选修人数。

    /*自定义变量@totalcno,@snotemp,@rec;输入变量@newCourse,@dept*/

    create proc addCourse(@newCourse char(40),@dept char(20))
    as
    declare @totalcno char(4);
    declare @snotemp char(5);
    declare @rec int;
    BEGIN
    if exists(select * from course where cname=@newCourse)
    return
    /*不存在*/
    else
    select @totalcno=MAX(cno) from course; /*找出最大课程编号*/
    set @totalcno=@totalcno+1;
    insert into course values(@totalcno,@newCourse,null,null); /*插入课程*/
    declare SX cursor for
    select sno from student where sdept=@dept; /*使用游标*/
    open SX;
    FETCH SX INTO @snotemp; /*推进游标*/
    while @@fetch_status=0 /*判断0 FETCH 语句成功。 -1 FETCH 语句失败或此行不在结果集中。 -2 被提取的行不存在。 */
    BEGIN
    insert into sc values(@snotemp,@totalcno,null);
    FETCH NEXT FROM SX INTO @snotemp;
    end
    close SX;
    select @rec=COUNT(*) from sc where cno=@totalcno; /*返回选课人数*/
    print @rec;
    end

  • 相关阅读:
    Java 设计模式-享元模式(Flyweight)
    Java 设计模式-状态模式模式(State)
    Java 设计模式-建造者模式(Builder)
    Java 设计模式-抽象工厂(Abstract Factory)
    Spring 之 JMS 基于JMS的RPC
    Spring 之 JMS 监听JMS消息
    Spring 之 JMS 发送和接收消息
    数据结构
    BFS vs DFS
    子集和排列
  • 原文地址:https://www.cnblogs.com/liwon/p/3468474.html
Copyright © 2011-2022 走看看