zoukankan      html  css  js  c++  java
  • 游标的作用

    < DOCTYPE html PUBLIC -WCDTD XHTML StrictEN httpwwwworgTRxhtmlDTDxhtml-strictdtd>

       
          关系数据库中的操作会对整个行集产生影响。由       SELECT       语句返回的行集包括所有满足该语句       WHERE       子句中条件的行。由语句所返回的这一完整的行集被称为结果集。应用程序,特别是交互式联机应用程序,并不总能将整个结果集作为一个单元来有效地处理。这些应用程序需要一种机制以便每次处理一行或一部分行。游标就是提供这种机制的结果集扩展。   
        
          游标通过以下方式扩展结果处理:     
        
          允许定位在结果集的特定行。   
        
        
          从结果集的当前位置检索一行或多行。   
        
        
          支持对结果集中当前位置的行进行数据修改。   
        
        
          为由其他用户对显示在结果集中的数据库数据所做的更改提供不同级别的可见性支持。   
        
        
          提供脚本、存储过程和触发器中使用的访问结果集中的数据的       Transact-SQL       语句。     
          请求游标   
          Microsoft&reg;       SQL       Server&#8482;       2000       支持两种请求游标的方法:     
        
          Transact-SQL     
          对根据       SQL-92       游标语法制定的游标,Transact-SQL       语言支持使用它们的语法。   
        
          数据库应用程序编程接口(API)游标函数     
          SQL       Server       支持这些数据库       API       的游标功能:   
        
          ADO(Microsoft       ActiveX&reg;       数据对象)   
        
        
          OLE       DB   
        
        
          ODBC(开放式数据库连接)   
        
        
          DB-Library     
          应用程序不能混合使用这两种请求游标的方法。已经使用       API       指定游标行为的应用程序不能再执行       Transact-SQL       DECLARE       CURSOR       语句请求一个       Transact-SQL       游标。只有在将所有       API       游标特性均设回默认值后,应用程序才可以执行       DECLARE       CURSOR。   
        
          如果       Transact-SQL       和       API       游标均未被请求,则默认情况下       SQL       Server       将一个完整的结果集返回给应用程序,这个结果集称为默认结果集。   
        
          游标进程   
          Transact-SQL       游标和       API       游标有不同的语法,但下列一般进程可用于所有       SQL       Server       游标:     
        
          把游标与       Transact-SQL       语句的结果集相关联,并且定义游标的特征,如是否能够更新游标中的行。   
        
        
          执行       Transact-SQL       语句以填充游标。   
        
        
          检索想要查看的游标中的行。从游标中检索一行或多行的操作称为提取。执行一系列的提取操作以向前或向后检索行的操作称为滚动。   
        
        
          根据需要,对游标中当前位置的行执行修改操作(更新或删除)。   
        
        
          关闭游标。     

    简单的说,跟C语言里的指针相识   
          可以随意移动到需要的行

    例:
    DECLARE cursor_name CURSOR
    [ LOCAL | GLOBAL ]
    [ FORWARD_ONLY | SCROLL ]
    [ STATIC | KEYSET | DYNAMIC | FAST_FORWARD ]
    [ READ_ONLY | SCROLL_LOCKS | OPTIMISTIC ]
    [ TYPE_WARNING ]
    FOR select_statement
    [ FOR UPDATE [ OF column_name [ ,...n ] ] ]

    打开该游标时所生成的结果集包括 pubs 数据库的 authors 表中的所有行和列。可以更新该游标,对该游标所做的所有更新和删除均在提取中表现出来。因为没指定 SCROLL 选项,FETCH NEXT 是唯一可用的提取选项。
    DECLARE authors_cursor CURSOR
         FOR SELECT * FROM authors
    OPEN authors_cursor
    FETCH NEXT FROM authors_cursor

    牵套游标
    declare      cursor      Cursor_Name      for     
         Select      *      from      table_Name      (for      read      only)   
         fetch      cursor_Name      to      variable_Name     
         ;   
         ;   
         ;    
    注:fetch      从 Transact-SQL 服务器游标中检索特定的一行。
      

  • 相关阅读:
    WPF 复制和粘贴
    WPF控件模拟双击事件
    WPF获取鼠标当前位置
    user32.dll
    C# 根据IP地址获取城市
    WPF 动态布局Grid
    手机自动化测试:Appium源码分析之跟踪代码分析五
    手机自动化测试:appium源码分析之bootstrap三
    手机自动化测试:appium源码分析之bootstrap二
    手机自动化测试:appium源码分析之bootstrap一
  • 原文地址:https://www.cnblogs.com/netcorner/p/2912366.html
Copyright © 2011-2022 走看看