mysql存储过程需要注意的

1.当使用游标赋值结果集时,变量名不能使用列明,不然赋值为null

BEGIN


DECLARE stopindex INT DEFAULT 0;

DECLARE id1 int;
DECLARE title VARCHAR(1000);
DECLARE description VARCHAR(1000);
DECLARE insertdate DATETIME;
DECLARE username VARCHAR(1000);
DECLARE closed int;
DECLARE commandtype  VARCHAR(1000);



DECLARE
		cur CURSOR FOR (
			<span style="color:#FF0000;">select id,zlmc,zlnr,fbsj,fbr,kg,zldj from jiaowei.five_instructions</span>
		);
DECLARE  CONTINUE HANDLER FOR NOT FOUND SET stopindex = 1;
OPEN cur;
<span style="color:#FF0000;">#如此处,游标查询的表有id字段,则遍历赋值时,不能再用id做变量,不然赋值字段为null</span>
FETCH cur INTO <span style="color:#FF0000;">id1</span>,title,description,insertdate,username,closed,commandtype;

WHILE (stopindex !=1) DO
  if closed=0 THEN
   set closed=1;
  ELSE
     set closed=0;
	end if;

	insert into  topic set id=id1,title=title,description=description,insertdate=insertdate
		,username=username,closed=closed,commandtype=commandtype,msgtype=0,type='指令';

FETCH cur INTO id1,title,description,insertdate,username,closed,commandtype;


END WHILE;

CLOSE cur;

END


2.当变量赋值使用 select id into 变量名 from  student where name= "ffff"  limit 0,1;  当查不到值时会报错运行中断。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值