2024年5月9日发(作者:)

sqlserver游标概念与实例全面解说

引言

我们先不讲游标的什么概念,步骤及语法,先来看一个例子:

表一 OriginSalary 表二 AddSalary

现在有2张表,一张是OriginSalary表--工资表,有三个字段0_ID 员工号(NVARCHAR)、

O_Name员工姓名(NVARCHAR)、O_Salary工资(FLOAT)。

另一张表AddSalary表—加薪表。有2个字段,O_ID员工号、A_Salary增加工资。两张表

的O_ID是一一对应的,现在求将加薪的工资+原来的工资=现在的工资,也就是O_Salary=

O_Salary+A_Salary,修改表OriginSalary的工资字段。

对于一些不熟悉游标的程序员来说,这个并不是什么很难的问题,这个问题用程序来实现可能也

很简单。我先说说,用程序解决这个问题的思路:

1. 先获得表OriginSalary的记录数,写个循环。

2. 写SQL语句“select * from Salary as A left join ary a

s B on A.O_ID=B.O_ID”获得视图。

3. 使用Dataset获得O_Salary=O_Salary+A_Salary。

4. 写UPDATE语句“update OriginSalary set O_Salary=”相加的值” where O_ID

=”获得值”

5. 循环3次,完成此功能。

还有一种方法就是写存储过程,在这里我就不列出来了。

我想大家在学习游标之前好好想想这个问题,及一些批量处理的例子。可能有的人会说:“难道

数据库不能一行一行的处理数据吗?将表AddSalary的数据逐行的取出,然后表 OriginSalar

y数据逐行的修改?”答案当然是肯定。这就是游标概念。接下来的一章我们会好好的讲讲什么

是游标?我会用游标来解决刚才留给大家的问题。

1.1游标的概念

游标(Cursor)它使用户可逐行访问由SQL Server返回的结果集。使用游标(cursor)的一个主

要的原因就是把集合操作转换成单个记录处理方式。用SQL语言从数据库中检索数据后,结果

放在内存的一块区域中,且结果往往是一个含有多个记录的集合。游标机制允许用户在SQL s

erver内逐行地访问这些记录,按照用户自己的意愿来显示和处理这些记录。

1.2 游标的优点

从游标定义可以得到游标的如下优点,这些优点使游标在实际应用中发挥了重要作用:

1)允许程序对由查询语句select返回的行集合中的每一行执行相同或不同的操作,而不是对

整个行集合执行同一个操作。

2)提供对基于游标位置的表中的行进行删除和更新的能力。

3)游标实际上作为面向集合的数据库管理系统(RDBMS)和面向行的程序设计之间的桥梁,

使这两种处理方式通过游标沟通起来。

1.3 游标的使用

讲了这个多游标的优点,现在我们就亲自来揭开游标的神秘的面纱。

使用游标的顺序: 声名游标、打开游标、读取数据、关闭游标、删除游标。

1.3.1声明游标

最简单游标声明:DECLARE <游标名>CURSOR FOR

其中select语句可以是简单查询,也可以是复杂的接连查询和嵌套查询

例子:[已表2 AddSalary为例子]

Declare mycursor cursor for select * from AddSalary

这样我就对表AddSalary申明了一个游标mycursor

【高级备注】

DECLARE <游标名> [INSENSITIVE] [SCROLL] CURSORFOR

这里我说一下游标中级应用中的[INSENSITIVE]和[SCROLL]

INSENSITIVE

表明MS SQL SERVER 会将游标定义所选取出来的数据记录存放在一临时表内(建立在tem

pdb 数据库下)。对该游标的读取操作皆由临时表来应答。因此,对基本表的修改并不影响游

标提取的数据,即游标不会随着基本表内容的改变而改变,同时也无法通过游标来更新基本表。

如果不使用该保留字,那么对基本表的更新、删除都会反映到游标中。

另外应该指出,当遇到以下情况发生时,游标将自动设定INSENSITIVE 选项。

a.在SELECT 语句中使用DISTINCT、 GROUP BY、 HAVING UNION 语句;

b.使用OUTER JOIN;

c.所选取的任意表没有索引;

d.将实数值当作选取的列。

SCROLL

表明所有的提取操作(如FIRST、 LAST、 PRIOR、 NEXT、 RELATIVE、 ABSOLUTE)

都可用。如果不使用该保留字,那么只能进行NEXT 提取操作。由此可见,SCROLL 极大地增

加了提取数据的灵活性,可以随意读取结果集中的任一行数据记录,而不必关闭再

重开游标。

1.3.2 打开游标

非常简单,我们就打开刚才我们声明的游标mycursor

OPEN mycursor