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

本文介绍了如何在存储过程中调用另一个存储过程,并演示了如何使用带有返回值的存储过程。此外,还详细讲解了游标的创建及使用方法,包括通过游标遍历表中的数据并进行插入操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

存储过程调用存储过程:

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

直接在存储过程中调用: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 






                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值