数据库游标

数据库游标
2007-10-10 15:40

游标提供了一种对从表中检索出的数据进行操作的灵活手段,就本质而言,游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。游标总是与一条T_SQL 选择语句相关联因为游标由结果集(可以是零条、一条或由相关的选择语句检索出的多条记录)和结果集中指向特定记录的游标位置组成。当决定对结果集进行处理时,必须声明一个指向该结果集的游标。

使用游标有四种基本的步骤:声明游标、打开游标、提取数据、关闭游标。

1.声明游标

同其它变量一样,我们也可以定义游标的访问类型:全局、共享、实例或局部,游标变量的命名规范建议也同其它变量一样。 declare my_cursor cursor keyset for select * from info

DECLARE CustomerCursor CURSOR FOR
SELECT acct_no,name,balance FROM customer WHERE province="北京";

2.打开游标
OPEN CustomerCursor;

3.提取数据
FETCH语句来取得数据。一条FETCH语句一次可以将一条记录放入程序员指定的变量中。已经声明并打开一个游标后,我们就可以将数据放入任意的变量中。在FETCH语句中您可以指定游标的名称和目标变量的名称。

--声明局部变量
declare @id int,@name varchar(20),@address varchar(20)
--定位到指定位置的记录
fetch absolute 56488 from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录相对位置记录
fetch relative -88 from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录前一条
fetch prior from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到当前记录后一条
fetch next from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到首记录
fetch first from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address
--定位到尾记录
fetch last from my_cursor into @id,@name,@address
select @id as id,@name as name,@address as address

注:如果提示“提取类型··不能用于只进游标”则在声明游标时:DECLARE MyCursor CURSOR SCROLL FOR ·· (FAST_FORWARD :只进游标 ; SCROLL: 滚动游标 )

示例:

DECLARE MyCursor CURSOR SCROLL FOR SELECT * FROM Test1

DECLARE @ROW1 int,@ROW2 char(10),@ROW3 char(10),@ROW4 char(10)

OPEN MyCursor

FETCH next FROM MyCursor INTO @ROW1, @ROW2, @ROW3, @ROW4

WHILE (@@fetch_status =0)
BEGIN

INSERT INTO Test1(id, a, b, c)
VALUES (@ROW1, @ROW2, @ROW3, @ROW4)

FETCH next FROM MyCursor INTO @ROW1, @ROW2, @ROW3, @ROW4

END
CLOSE MyCursor
DEALLOCATE MyCursor

(示例是将Test1表中的数据复制一次!)

(@@fetch_status 返回被 fetch 语句执行的最后游标的状态,而不是任何当前被连接打开的游标的状态。0 fetch 语句成功;-1 fetch语句失败或此行不在结果集中;-2 被提取的行不存在;所以使用@@fetch_status=0判断是否游标到了最后一行

高级应用

修改当前游标所在行的信息,我们可以如下操作:
UPDATE table1
SET balance=1000
WHERE CURRENT of yourCursor;
删除当前行的操作如下:
DELETE FROM table1
WHERE CURRENT OF yourCursor;

此时声明游标的时候:declare my_cursor cursor scroll dynamic for ···
scroll表示可随意移动游标指针(否则只能向前),dynamic表示可以读写游标(否则游标只读)

你可能感兴趣的:(sql)