需求分析:需要大量的进行数据库数据修改,有一定的数据关联性。
网上成品游标使用的 存储过程如下:
/*判断是否存在,如果存在就删除*/
drop procedure if exists tempProcedure_Test;/*取一个系统中绝对不会用到的存储过程名称*/
/*创建临时存储过程*/
create procedure tempProcedure_Test()
BEGIN
declare isDone int default 0; /*判断是否还有记录*/
declare intNumber int default 1;/*用于自增的变量*/
declare tempId char(36); /*每条记录循环时的临时ID*/
declare folderIds cursor for select A.ID from case_folder_info as A;/*取出来所有需要循环的数据*/
declare continue handler for not FOUND set isDone = 1;/*如果不存在就设置为1,即为true*/
open folderIds; /*OPEN*/
REPEAT /*开始循环数据*/
fetch folderIds into tempId;
if not isDone THEN
update case_folder_info set SORT_NUMBER=intNumber where id=tempId;
set intNumber=intNumber+1;
end if;
until isDone end repeat;
close folderIds; /*CLOSE,对应上面的open folderIds;*/
END;
call tempProcedure_Test();/*调用下这个临时的存储过程*/
drop procedure tempProcedure_Test; /*使用完毕后要删除垃圾*/
代码中备注已十分清晰明了的写明游标的使用方法和相关参数的传递。一下是自己整理的相关注意事项,以便后面自己及时处理问题。
1.注意游标的设置需要注意写法。
declare folderIds cursor for select A.ID from case_folder_info as A;/*取出来所有需要循环的数据*/
在这里很多同学想的是直接在”cursor select “后面直接加上自己想要储存的游标,不考虑在存储过程中对于数据的识别。会造成游标储存数据为空的现象。比如写成"declare folderIds cursor for select ID from case_folder_info; "由于没有使用别名,导致存储过程中的游标没有正确储存表格数据,想要详细了解的可以咨询问下度娘。
2.代码语句的准确性
可以在实例代码中发现很多分号";"作为语句结尾,这个是做为新手需要仔细关注的一个地方,不然莫名的提示语法错误很浪费大量的工作时间和精力
3.游标的循环设置和开启关闭
declare isDone int default 0; /*判断是否还有记录*/
declare continue handler for not FOUND set isDone = 1;/*如果不存在就设置为1,即为true*/
open folderIds; /*OPEN*/
REPEAT /*开始循环数据*/
end if;
until isDone end repeat;
close folderIds; /*CLOSE,对应上面的open folderIds;*/
上面的代码是对实列代码简化,其中下面代码的意义就是判断游标数据是否为空,同时以该条件终止循环。
declare continue handler for not FOUND set isDone = 1;/*如果不存在就设置为1,即为true*/
until isDone end repeat;
最后使用游标前要打开
open folderIds; /*OPEN*/
使用完后要关闭
close folderIds;