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

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

引言

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

表一 OriginSalary 表二 AddSalary

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

CHAR)、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

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

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

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

e O_ID=”获得值”

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

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

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

说:“难道数据库不能一行一行的处理数据吗?将表AddSalary的数据逐行的取出,然后

表 OriginSalary数据逐行的修改?”答案当然是肯定。这就是游标概念。接下来的一章我

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

1.1游标的概念

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

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

数据后,结果放在内存的一块区域中,且结果往往是一个含有多个记录的集合。游标机制

允许用户在SQL server内逐行地访问这些记录,按照用户自己的意愿来显示和处理这些

记录。

1.2 游标的优点

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