mysql 游标多值_MySQL游标多一次循环

触发器代码片段如下:

declare c_name cursor for select b.id from asset_db_priv a,mc$priv_database b where a.node_name=b.priv_name and a.p_node_name=new.name;

DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;

set pnid=new.id;

open c_name;

REPEAT

fetch c_name into p_id;

insert into db_operation_priv(op_id,priv_db_id,status) values (pnid,p_id,'1');

UNTIL done END REPEAT;

close c_name;

发现db_operation_priv表格会被多插一条记录(最后一条重复)。查看触发器代码很明显done = 1时还会执行一次insert,那么在insert之前加一层判断即可。我先加了if not done then或者if done<>1 then,发现insert 一次都没有执行,将done值插入测试表发现done在变为1之前都是null,改为if done is null then即可。

改好的代码片段如下:

declare c_name cursor for select b.id from asset_db_priv a,mc$priv_database b where a.node_name=b.priv_name and a.p_node_name=new.name;

DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;

set pnid=new.id;

open c_name;

REPEAT

fetch c_name into p_id;

if done is null then

insert into db_operation_priv(op_id,priv_db_id,status) values (pnid,p_id,'1');

end if;

UNTIL done END REPEAT;

close c_name;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值