SQL Server数据库原理及应用 第二版 教学课件 作者 曾长军 第 11 章 游标和其他概念.pptVIP

SQL Server数据库原理及应用 第二版 教学课件 作者 曾长军 第 11 章 游标和其他概念.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第 11 章 游标和其他概念 11.1 游 标 游标是SQL Server提供的一种机制,它能够对一个结果集进行逐行处理,其工作方式类似于指针,可以指向结果集中的任意位置以此对指定位置的数据进行处理。 使用游标要遵循声明游标→打开游标→读取游标→关闭游标→删除游标的顺序。 11.2 游 标 定 义 1.SQL标准的游标声明 语法: DECLARE cursor_name [ INSENSITIVE | SCROLL ] CURSOR FOR select_statement [ FOR { READ ONLY | UPDATE [ OF column_name[,…] ] } ] 参数说明: ① cursor_name:游标名。由用户自定义,命名要符合命名规则。 ② INSENSITIVE:指定系统将创建供所定义的游标使用的数据的临时摹本,对游标的所有请求都从tempdb中的该临时表中得到应答。因此,在对该游标进行提取操作时,返回的数据中不反映对基本表所做的修改,并且该游标不允许修改。如果省略INSENSITIVE,则任何用户对基本表提交的删除和更新都反映在后面的提取中。 ③ SCROLL:说明所声明的游标可以前滚、后滚,可使用所有的提取选项(FIRST、LAST、PRIOR、NEXT、RELATIVE、ABSOLUTE)。如果省略SCROLL,则只能使用NEXT提取 选项。 ④ select_statement:SELECT语句,由该查询产生与所示声明的游标相关联的结果集。在SELECT语句中不能出现COMPUTE、COMPUTE BY、INTO和FOR BROWSE这样的关键字。 ⑤ READ ONLY:说明所声明的游标是只读的。 ⑥ UPDATE [ OF column_name[,…] ]:UPDATE指定游标中可以更新的列,用参数OF column_name [,…]指定可以修改的列。若没有用OF column_name [,…]指定,则表明是要修改所有的列。 2.T-SQL扩充的游标声明 语法: DECLARE cursor_name CURSOR [LOCAL|GLOBAL] [FORWORD_ONLY|SCROLL] [STATIC|KEYSET|DYNAMIC|FAST_FORWARD] [READ_ONLY|SCROLL_LOCKS|OPTIMISTIC] [TYPE_WARNING] FOR select_statement [FOR UPDATE [OF column_name[,…]]] 参数说明: LOCAL|GLOBAL:说明游标的作用域。若两者均未指定时,则默认值由default to local cursor数据库选项的设置控制。 FORWORD_ONLY|SCROLL:说明游标的移动方向。FORWORD_ONLY表示只能从第一行滚动到最后一行。SCROLL含义与SQL-92标准相同。 STATIC|KEYSET|DYNAMIC|FAST_FORWARD:定义游标的类型。这个选项能显示出原数据库的更新操作(UPDATE、INSERT、DELETE)能否反映到打开的游标中。 STATIC:静态游标。含义同SQL-92标准的INSENSITIVE关键字功能相同。游标打开后,数据库用户对数据库的更新操作不会反映到该类型游标中。 KEYSET:键集游标。该类型游标由称为键的列或列的组合控制。特点是行顺序固定。可以通过该类型游标修改数据库中表的非关键字列的值,但不可插入数据。 DYNAMIC:动态游标。与静态游标正好相反。 FAST_FORWARD:只进游标。它是只进的游标,但做过优化。对数据库的更新操作是可以反映到该类型中的。 游标类型与移动方向之间的关系: 1)若移动方向FORWARD_ONLY和SCROLL都没有指定,那么移动方向关键字的默认值由以下条件决定:若指定了游标类型为STATIC、KEYSET或DYNAMIC,则移动方向默认值为SCROLL;若没有用STATIC、KEYSET或DYNAMIC关键字指定游标类型,则移动方向默认值为FORWARD_ONLY。 2)FAST_FORWARD不能与SCROLL一起使用,且FAST_FORWARD与FORWARD_ONLY只能选用一个。 3)若指定了移动方向为FORWARD_ONLY,而没有用STATIC、KEYSET或DYNAMIC关键字指定游标类型,则默认所定义的游标为动态游标。 READ_ONLY|SCROLL_LOCKS|OPTIMISTIC:说明游标或基表的访问属性。 READ_O

您可能关注的文档

文档评论(0)

118压缩包课件库 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档