MySQL通过游标来实现通过查询结果集循环
时间:2021-07-01 10:21:17
帮助过:168人阅读
if exists proc_tmp;
create procedure proc_tmp()
BEGIN
/*这种写法也可以:DECLARE
done
INT
DEFAULT
FALSE
;
*/
declare done int default 0; /*用于判断是否结束循环*/
declare hostId bigint; /*用于存储结果集S_S的记录(因为我这里S_S的记录只有一列且为bigint类型)*/
/*定义游标*/
declare idCur cursor for select A.HostId
from dev_host
as A, sys_hostconfig
as B
where A.HostId !=
B.HostId;
/*定义 设置循环结束标识done值怎么改变 的逻辑*/
declare continue handler for not FOUND
set done =
1; /*done = true;亦可*/
open idCur; /*打开游标*/
REPEAT
fetch idCur into hostId; /*这部分可以看看书,还可以fetch多列(假设结果集S_S的记录不是单列的话)*/
if not done THEN /*数值为非0,MySQL认为是true*/
insert into sys_hostconfig(HostId, AElecCap, BElecCap, CElecCap, RemElecCap, ATmpCap, BTmpCap, CTmpCap, BoxTmpCap, CreateTime)
/*注意这里用到了hostId和now()*/
values(hostId, 80,
80,
80,
500,
80,
80,
80,
80, NOW());
end if;
until done end repeat;
close idCur; /*关闭游标*/
END
call proc_tmp();
drop procedure proc_tmp; /*删除临时存储过程*/
MySQL通过游标来实现通过查询结果集循环
标签:删除 rom dev cursor continue 查询 cap 设置 部分