mysql 存储过程游标的使用及存储过程调用存储过程

存储过程调用存储过程:

其实很简单。。。如果不带返回值

直接在存储过程中调用:call 存储过程名称(参数)

如果有返回值

call generatorAuthorCode(@c);   select @c into authorCode;

游标使用:

DECLARE  cur_name CURSOR FOR select field from table_name ; #我的理解这个cur_name 可以看成一个集合

open cur_name; //开启

FETCH cur_mark INTO markName; //获取值

#内容

close cur_name; //关闭

举个栗子:

BEGIN
	DECLARE markCount int; #mark标签总数
	DECLARE iniCount int DEFAULT 0; #循环初始状态 ,初始值为0
	DECLARE markName VARCHAR(20);# 定义标签名
	DECLARE cur_mark CURSOR FOR select mark_name from yq_book_mark;
	select count(1) into markCount from yq_book_mark;   #查询mark总数
	OPEN cur_mark;
	FETCH cur_mark INTO markName;  #。。。
	while iniCount <= markCount DO     #循环将yq_book_mark表中的数据存入
		INSERT INTO yq_tags (tag_name,tag_status,create_time,create_user) VALUES(markName,'0',NOW(),'admin');
	set iniCount = iniCount + 1;
	FETCH cur_mark INTO markName; #。。。每次遍历取的值都不一样
	end while;
	close cur_mark;

END 





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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值