现在有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的工资字段。 对于一些不熟悉游标的程序员来说,这个并不是什么很难的问题,这个问题用程序来实现可能也很简单。我先说说,用ASP.NET程序解决这个问题的思路: 1. 先获得表OriginSalary的记录数,写个循环。 2. 写SQL语句“select * from dbo.OriginSalary as A left join dbo.AddSalary as 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的数据逐行的取出,然后表 OriginSalary数据逐行的修改?”答案当然是肯定。这就是游标概念。接下来的一章我们会好好的讲讲什么是游标?我会用游标来解决刚才留给大家的问题。
通过实例我们可以看到游标逐行逐行都把值都取出来了。那么我请大家先不看下面的答案,在引言部分我刚才留个大家的问题试一下能不能解决? 现在我们写一个存储过程解决刚才我留下来的问题吧 CREATE PROCEDURE PK_SalaryAdd AS declare @O_ID nvarchar(20),@A_Salary float declare mycursor cursor for select O_ID,A_Salary from AddSalary open mycursor fetch next from mycursor into @O_ID,@A_Salary while(@@fetch_status = 0) begin Update OriginSalary set O_Salary=O_Salary+@A_Salary where O_ID=@O_ID fetch next from mycursor into @O_ID,@A_Salary end close mycursor deallocate mycursor GO