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
- select * from table1
- open cursor1
-
- fetch next from cursor1 into @id,@name
-
- while @@fetch_status=0
- begin
- update table1 set name=name+'1'
- where id=@id
-
- fetch next from cursor1 into @id,@name
- 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 游标名称 (删除游标)
三、嵌套循环:
案例: 红色部分是对于第二点常用格式上的添加,使得可以在循环中嵌套循环
TYPE daynamic_cursor_type IS REF CURSOR; --黄色部分自定义
FROM DB_YWBZ.ecm_bscl_common_content_data@db_ywbz_sc_old d
WHERE d.bscl_mc is not null
cur_zj_rows daynamic_cursor_type; --定义游标
dbms_output.enable(buffer_size=>null);
for v_bscl_mc_cur in bscl_mc_cur loop
v_sql := 'SELECT zj,ZJ_DM FROM ecm_bscl_common_content_data d WHERE d.bscl_mc = '||chr(39)||v_bscl_mc_cur.bscl_mc||chr(39); --引号,记得加
dbms_output.put_line('=========='||v_bscl_mc_cur.bscl_mc);
open cur_zj_rows for v_sql;
FETCH cur_zj_rows INTO v_zj; --获取值
EXIT WHEN cur_zj_rows%NOTFOUND; --判断是否存在值
dbms_output.put_line(v_zj); --操作