MySQL知识总结(三)存储过程
1. 创建存储过程
1.1 无参数存储过程
CREATE PROCEDURE bruce_procedure () BEGIN --1.声明变量 --2.执行业务逻辑 END
1.2 有参数的存储过程
CREATE PROCEDURE bruce_procedure ( IN in_exam_id INT, in_student_types_id VARCHAR (100) ) BEGIN --1.声明变量 --2.执行业务逻辑 END
IN 表示输入参数
2. 调用存储过程
--无参调用 Call bruce_procedure(); --有参调用 Call bruce_procedure(1,’2,1’);
3. 删除存储过程
Drop procedure bruce_procedure;
4. 查看存储过程信息
1) show procedure status
显示数据库中所有存储的存储过程基本信息,包括所属数据库,存储过程名称,创建时间等
2) show create procedure sp_name
显示某一个存储过程的详细信息
5. 声明变量
CREATE PROCEDURE sc_st_group_courses_class_procedure ( IN in_exam_id INT, in_student_types_id VARCHAR (100) ) BEGIN -- 组织课程组关系id DECLARE v_group_courses_id INT; -- 考试组织id DECLARE v_exam_group_id INT; END
1) 可以在存储过程全局范围内声明
2) 如果要在局部范围内声明,需重新定义begin end,并在begin和end之间声明变量
6. If
if stop = 1 then leave cur_loop; end if;
7. 循环
7.1 结构
cur_loop : loop //业务逻辑 end loop //结束循环
7.2 跳出循环
leave cur_loop;
8. 游标
8.1 声明游标
CREATE PROCEDURE sc_st_group_courses_class_procedure() BEGIN DECLARE STOP INT DEFAULT 0; -- 创建游标 DECLARE cur CURSOR FOR ( select group_courses_id, exam_group_id, courses_id, class_id from sc_group_courses_view WHERE group_class='class' and exam_id = in_exam_id ); -- 游标捕捉越界异常 DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET STOP = 1; END
8.2 打开和关闭游标
打开游标:OPEN cur
关闭游标:CLOSE cur
8.3 遍历游标
CREATE PROCEDURE sc_st_group_courses_class_procedure() BEGIN DECLARE STOP INT DEFAULT 0; -- 创建游标 DECLARE cur CURSOR FOR ( select group_courses_id, exam_group_id, courses_id, class_id from sc_group_courses_view WHERE group_class='class' and exam_id = in_exam_id ); -- 游标捕捉越界异常 DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET STOP = 1; -- 开启游标 OPEN cur; -- 开始循环 cur_loop : loop FETCH cur INTO v_group_courses_id, v_exam_group_id, v_courses_id, v_class_id ; -- 判断游标溢出 if stop = 1 then leave cur_loop; end if; -- 结束循环 END loop cur_loop; -- 关闭游标 CLOSE cur; END
9. 给变量赋值
DECLARE v_median_index int;
set v_median_index = v_class_count/2-1;
10. 查询并赋值给变量
select max(sum_score),min(sum_score),avg(sum_score),STD(sum_score) into v_highest_score, v_lowest_score, v_average, v_std from a ;
11. 参考
作者:风过无痕-唐
出处:http://www.cnblogs.com/tangyanbo/
本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。 如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。欢迎加QQ讨论群
出处:http://www.cnblogs.com/tangyanbo/
本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。 如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。欢迎加QQ讨论群
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?