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 <游标名>;
     
    例子:
    CREATE PROCEDURE [dbo].[pro_CURSOR]
    AS
    BEGIN

    --声明一个游标
    DECLARE MyCURSOR CURSOR FOR 
    SELECT userid,depid FROM users

    --打开游标
    open MyCURSOR

    --声明两个变量
    declare @userid varchar(50)
    declare @depid varchar(50)

    --循环移动
    --这里会把select的变量赋给(@userid,@depid)所以select的列和变量的数量和顺序要一样
    fetch next from MyCURSOR into @userid,@depid
    while(@@fetch_status=0)
      
    begin
        
    update users set description=(select dep_des from department where depid=@depid)
    where userid=@userid
        
    fetch next from MyCURSOR into @userid,@depid
      
    end

    close MyCURSOR
    deallocate MyCURSOR

    END

     

    总结:游标就是C#中的ForEatch一个list

     


  • 相关阅读:
    默认使用什么序列化框架,你知道的还有哪些?
    一般使用什么注册中心?还有别的选择吗?
    Dubbo 的整体架构设计有哪些分层?
    Java 中是如何支持正则表达式操作的?
    Dubbo 集群容错有几种方案?
    Dubbo 推荐用什么协议?
    说说核心的配置有哪些?
    Dubbo 如何优雅停机?
    Dubbo 必须依赖的包有哪些?
    服务上线怎么兼容旧版本?
  • 原文地址:https://www.cnblogs.com/linyijia/p/1864602.html
Copyright © 2011-2022 走看看