0

0

SQL Server 7.0 入门(七)

黄舟

黄舟

发布时间:2016-12-24 17:40:56

|

1475人浏览过

|

来源于php中文网

原创

i.              声明游标
在这一步中,需要指定游标的属性和根据要求产生的结果集。有两种方法可以指定一个游标。
形式1  (ansi 92)
declare cursor_name [insensitive] [scroll] cursor
for select_statement
[for {read only | update ][of column_list]}]
形式2
declare cursor_name cursor
[local | global]
[forward_only | scroll]
[static | keyset | dynamic]
[read_only | scroll_locks | optimistic]
for select_statement
[for {read only | update ][of column_list]}]
insensitive关键字指明要为检索到的结果集建立一个临时拷贝,以后的数据从这个临时拷贝中获取。如果在后来游标处理的过程中,原有基表中数据发生了改变,那么它们对于该游标而言是不可见的。这种不敏感的游标不允许数据更改。
scroll关键字指明游标可以在任意方向上滚动。所有的fetch选项(first、last、next、relative、absolute)都可以在游标中使用。如果忽略该选项,则游标只能向前滚动(next)。
select_statement指明sql语句建立的结果集。transact sql语句compute、compute by、for browse和into在游标声明的选择语句中不允许使用。
read only指明在游标结果集中不允许进行数据修改。
update关键字指明游标的结果集可以修改。
of column_list指明结果集中可以进行修改的列。缺省情况下(使用update关键字),所有的列都可进行修改。
local关键字指明游标是局部的,它只能在它所声明的过程中使用。
global关键字使得游标对于整个连接全局可见。全局的游标在连接激活的任何时候都是可用的。只有当连接结束时,游标才不再可用。
forward_only指明游标只能向前滚动。
static的游标与insensitive的游标是相同的。
keyset指明选取的行的顺序。sql server将从结果集中创建一个临时关键字集。如果对数据库的非关键字列进行了修改,则它们对游标是可见的。因为是固定的关键字集合,所以对关键字列进行修改或新插入列是不可见的。
dynamic指明游标将反映所有对结果集的修改。
scroll_lock是为了保证游标操作的成功,而对修改或删除加锁。
optimistic指明哪些通过游标进行的修改或者删除将不会成功。
注意:
· 如果在select语句中使用了distinct、union、group by语句,且在选择中包含了聚合表达式,则游标自动为insensitive的游标。
· 如果基表没有唯一的索引,则游标创建成insensitive的游标。
· 如果select语句包含了order by,而被order by的列并非唯一的行标识,则dynamic游标将转换成keyset游标。如果keyset游标不能打开,则将转换成insensitive游标。使用sql ansi-92语法定义的游标同样如此,只是没有insensitive关键字而已。
                       ii.              打开游标
打开游标就是创建结果集。游标通过declare语句定义,但其实际的执行是通过open语句。语法如下:
open { { [global] cursor_name } | cursor_variable_name}
global指明一个全局游标。
cursor_name是被打开的游标的名称。
cursor_variable_name是所引用游标的变量名。该变量应该为游标类型。
在游标被打开之后,系统变量@@cursor_rows可以用来检测结果集的行数。@@cursor_rows为负数时,表示游标正在被异步迁移,其绝对值(如果@@cursor_rows为-5,则绝对值为5)为当前结果集的行数。异步游标使用户在游标被完全迁移时仍然能够访问游标的结果。
                      iii.              从游标中取值
在从游标中取值的过程中,可以在结果集中的每一行上来回移动和处理。如果游标定义成了可滚动的(在声明时使用scroll关键字),则任何时候都可取出结果集中的任意行。对于非滚动的游标,只能对当前行的下一行实施取操作。结果集可以取到局部变量中。fetch命令的语法如下:
fetch [next | prior| first | last | absolute {n | @nvar} | relative {n | @nvar}]
from [global] cursor_name} | cursor_variable_name}
[into @variable_name ][,……n]]
next指明从当前行的下一行取值。
prior指明从当前行的前一行取值。
first是结果集的第一行。
last是结果集的最后一行。
absolute n表示结果集中的第n行,该行数同样可以通过一个局部变量传播。行号从0开始,所以n为0时不能得到任何行。
relative n表示要取出的行在当前行的前n行或后n行的位置上。如果该值为正数,则要取出的行在当前行前n行的位置上,如果该值为负数,则返回当前行的后n行。
into @cursor_variable_name表示游标列值存储的地方的变量列表。该列表中的变量数应该与declare语句中选择语句所使用的变量数相同。变量的数据类型也应该与被选择列的数据类型相同。直到下一次使用fetch语句之前,变量中的值都会一直保持。
每一次fetch的执行都存储在系统变量@@fetch_status中。如果fetch成功,则@@fetch_status被设置成0。@@fetch_status为-1表示已经到达了结果集的一部分(例如,在游标被打开之后,基表中的行被删除)。@@fetch_status可以用来构造游标处理的循环。
例如:
declare @iname char(20), @fname char(20)
open author_cur
fetch first from author_cur into @iname, @fname
while @@fetch_status = 0
begin
if @fname = ‘albert’
print “found albert ringer”
else
print “other ringer”
fetch next from author_cur into @iname, @fname
end
                     iv.              关闭游标
close语句用来关闭游标并释放结果集。游标关闭之后,不能再执行fetch操作。如果还需要使用fetch语句,则要重新打开游标。语法如下:
close [global] cursor_name | cursor_variable_name
                       v.              释放游标
游标使用不再需要之后,要释放游标。deallocate语句释放数据结构和游标所加的锁。语法如下:
deallocate [global] cursor_name | cursor_variable_name

       下面给出游标的一个完整的例子:
       use master
       go
       create procedure sp_buildindexes
       as
       declare @tablename sysname, @msg varchar(100), @cmd varchar(100)

       declare table_cur cursor for
       select name from sysobjects where type=’u’

       open table_cur
       fetch next from table_cur into @tablename
       
       while @@fetch_status = 0
       begin
              if @@fetch_status = -2
                     continue
              select @msg = “building indexes for table”+@tablename+”…”
              print @msg
              select @cmd = “dbcc dbreindex (‘”+@tablename+”')”
              exec (@cmd)
              print “    “
              fetch next from table_cur into @tablename
       end
       deallocate table_cur
       go
       下面的脚本将为pubs数据库执行sp_buildindexes
       use pubs
       go
       exec ap_buildindexes
       注意:上面也是创建用户定义的系统存储过程的示例。

使用临时表
       临时表是在tempdb中创建的表。临时表的名称都以“#”开头。临时表的范围为创建临时表的连接。因为,临时表不能在两个连接之间共享,一旦连接关闭,临时表就会被丢弃。如果临时表被创建于存储过程之中,则临时表的范围在存储过程之中,或者被该存储过程调用的任何存储过程之中。如果需要在连接之间共享临时表,则需要使用全局的临时表。全局的临时表以“##”符号开头,它将一直存在于数据库中,直到sql server重新启动。一旦这类临时表创建之后,所有的用户都可以访问到。在临时表上不能明确地指明权限。       临时表提供了存储中间结果的能力。有时候,临时表还能通过将一个复杂的查询分解成两个查询而获得性能的改善。这可以通过首先将第一个查询的结果存在临时表中,然后在第二个查询中使用临时表来实现。当一个大表中的某个子集在一个在座过程中使用多次时,建议使用临时表。在这种情况下,在临时表中保持数据的子集,以在随后的连接中使用,这样能大大改善性能。还可以在临时表中创建索引。 

 以上就是SQL Server 7.0 入门(七)的内容,更多相关内容请关注PHP中文网(www.php.cn)!

Wordware
Wordware

Wordware是一个自然语言编程工具,使任何人都可以开发、迭代和部署有用的AI应用程序。

下载

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

23

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

9

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

96

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

11

2026.02.12

Next.js全栈开发与SSR服务端渲染实战
Next.js全栈开发与SSR服务端渲染实战

本专题系统讲解 Next.js 框架在现代全栈开发中的应用,重点解析 SSR、SSG 与 ISR 渲染模式的原理与差异。内容涵盖路由系统、API Routes、数据获取策略、性能优化以及部署实践。通过完整项目示例,帮助开发者掌握高性能 SEO 友好的 React 全栈开发方案。

11

2026.02.12

Kotlin协程编程与Spring Boot集成实践
Kotlin协程编程与Spring Boot集成实践

本专题围绕 Kotlin 协程机制展开,深入讲解挂起函数、协程作用域、结构化并发与异常处理机制,并结合 Spring Boot 展示协程在后端开发中的实际应用。内容涵盖异步接口设计、数据库调用优化、线程资源管理以及性能调优策略,帮助开发者构建更加简洁高效的 Kotlin 后端服务架构。

90

2026.02.12

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

369

2026.02.11

Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析
Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析

本专题全面整理了Yandex搜索引擎的官方入口信息,涵盖国际版与俄罗斯版官网访问方式、网页版直达入口及免登录使用说明,帮助用户快速、安全地进入Yandex官网,高效使用其搜索与相关服务。

1322

2026.02.11

虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法
虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法

本专题系统整理了虫虫漫画官网及网页版最新入口,涵盖免登录观看、正版漫画全集在线阅读方式,并汇总稳定可用的访问渠道,帮助用户快速找到虫虫漫画官方页面,轻松在线阅读各类热门漫画内容。

105

2026.02.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.9万人学习

SQL优化与排查(MySQL版)
SQL优化与排查(MySQL版)

共26课时 | 2.4万人学习

MySQL索引优化解决方案
MySQL索引优化解决方案

共23课时 | 2.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号