sql 中CURSOR 的使用
目录
CURSOR是游标,常用于脚本处理。
这里主要介绍自己常用的方法,同时也会把网上的一般格式进行解释。
一、游标一般格式:
DECLARE 游标名称 CURSOR FOR SELECT 字段1,字段2,字段3,… FROM 表名 WHERE …
OPEN 游标名称
FETCH NEXT FROM 游标名称 INTO 变量名1,变量名2,变量名3,…
WHILE @@FETCH_STATUS=0
BEGIN
SQL语句执行过程… …
FETCH NEXT FROM 游标名称 INTO 变量名1,变量名2,变量名3,…
END
CLOSE 游标名称
DEALLOCATE 游标名称 (删除游标)
一般格式sql举例如下:
table1结构如下
id int
name varchar(50)
declare @id int
declare @name varchar(50)
declare cursor1 cursor for --定义游标cursor1
select * from table1 --使用游标的对象(跟据需要填入select文)
open cursor1 --打开游标
fetch next from cursor1 into @id,@name --将游标向下移1行,获取的数据放入之前定义的变量@id,@name中
while @@fetch_status=0 --判断是否成功获取数据 进入循环
begin
update table1 set name=name+'1'
where id=@id --进行相应处理(跟据需要填入SQL文)
fetch next from cursor1 into @id,@name --将游标向下移1行 相当于for(int i;i<n;i++) 中的i+1
end
close cursor1 --关闭游标
deallocate cursor1
其中while循环的判断条件:
@@FETCH_STATUS =0 FETCH 语句成功
@@FETCH_STATUS =-1 FETCH 语句失败或此行不在结果集中
@@FETCH_STATUS =-2 被提取的行不存在
二、我常用的一般格式:
DECLARE 游标名称 CURSOR FOR SELECT * FROM 表名 WHERE …
begin
dbms_output.enable(buffer_size=>null);
for 变量名 in 游标名称 loop
SQL语句执行过程… … 获取游标里的值 直接用 变量名.字段名
END LOOP;
CLOSE 游标名称
DEALLOCATE 游标名称 (删除游标)
三、嵌套循环:
案例: 红色部分是对于第二点常用格式上的添加,使得可以在循环中嵌套循环
转载自:https://blog.csdn.net/a876030877/article/details/79923410