MySQL存储过程的实现及其高级特性的应用
创作时间:
作者:
@小白创作中心
MySQL存储过程的实现及其高级特性的应用
引用
CSDN
1.
https://blog.csdn.net/zhouwensmile/article/details/143624290
MySQL存储过程是数据库管理中的重要工具,它能够帮助开发者实现复杂数据库操作的自动化,提高数据库管理效率。本文详细介绍了MySQL存储过程的各种功能和技术细节,包括变量的定义与赋值、传入与传出参数、条件语句(如if-then-else)、循环语句(如while和repeat)、游标的使用方法、函数的定义与使用以及事件调度器(Event)。同时,还包括了一些高阶特性和综合案例,如使用Python脚本与MySQL存储过程结合进行数据归档和清理。
变量
变量赋值1
DROP PROCEDURE IF EXISTS employees.testc ;
DELIMITER $$ -- 在一个成熟的sql客户端中这些语句都用自己写
$$ -- 自用写好create procedure的主体内容就行
CREATE DEFINER=`root`@`localhost` PROCEDURE `employees`.`testc`()
begin
declare my_uname varchar(32) default ''; -- 定义一个变量
set my_uname = 'duohappy'; -- 给变量赋值
select my_uname; -- 显示这个变量
end $$
DELIMITER ;
变量赋值2
CREATE DEFINER=`root`@`localhost` PROCEDURE `employees`.`testc`()
begin
declare my_uname varchar(32) default ''; -- 定义一个变量
select first_name into my_uname from employees where emp_no = 10001; -- 给变量赋值
select my_uname; -- 显示这个变量
end
变量的作用范围
CREATE DEFINER=`root`@`localhost` PROCEDURE `employees`.`testc`()
begin
declare emp_cnt int default 0; -- 全局变量
declare title_cnt int default 0;
begin
select count(*) into emp_cnt from employees;
select count(*) into title_cnt from titles;
select emp_cnt, title_cnt; -- 可以调用emp_cnt,title_cnt
end;
begin
declare max_birth date;
declare min_birth date;
select max(birth_date), min(birth_date) into max_birth, min_birth from employees;
select emp_cnt, title_cnt, max_birth, min_birth; -- 同样可以调用
end;
end
传参
传入参数 in
CREATE PROCEDURE employees.testa(in my_emp_no int) -- 参数类型是int,用来传入
begin
declare my_birth date;
select birth_date into my_birth from employees where emp_no = my_emp_no;
select my_emp_no, my_birth;
END
传出参数 out
CREATE PROCEDURE employees.testa(in my_emp_no int, out my_birth date) -- 传入,传出参数
begin
select birth_date into my_birth from employees where emp_no = my_emp_no;
select my_emp_no, my_birth; -- 外部定义了变量接收这个传出参数的话,可以不用在内部select
END
在调用的时候,必须定义一个变量,用于接收传出参数的值
命令行操作
set @my_birth := ''; -- 定义一个变量
call testa(10001, @my_birth); -- 变量用于接收传出参数
select @my_birth; -- 得到变量的值
传入传出参数 inout
CREATE PROCEDURE employees.testa(inout my_emp_no int, inout my_birth date) -- 传入传出
begin
set my_emp_no = 10001;
set my_birth = 0;
select my_emp_no, birth_date into my_emp_no, my_birth from employees where emp_no = my_emp_no;
END
可以传出传入,那么可以方便的在外部接收变量
命令行操作
set @my_emp_no := 0; -- 定义一个变量
set @my_birth := 0;
call testa(@my_emp_no, @my_birth);
select @my_emp_no, @my_birth;
条件语句
if-then-else-end if
热门推荐
麦芽糖浆的传统制作方法
团队竞技如何选装备?从角色职责到实战策略的全方位指南
定位误差的分析与计算
60岁老人情绪差怎么办?七大实用建议助力改善老人情绪
沙袋的种类有哪些 拳击沙袋选购及打法训练
核心利润率是什么?多少合适?
交互思维的定义和重要性
园艺剪刀使用指南:如何保持锋利及去除锈迹
麴义“白马”绰号由来解析
生物和非生物的区别有哪些
那些你不知道的北京地儿 探寻隐秘的文化瑰宝
怎样选择有利于孩子生长发育的户外运动?
生字背后的故事:解读汉字的历史与演变
船已经翻了一半?民调:过半美国人对特朗普持负面看法
黄连上清片与牛黄解毒片大比拼,哪个更适合你?
三支一扶与事业单位的区别是什么?
云南昆明:新型公共文化空间为幸福添彩
非油炸方便面是否会影响血脂
超级计算机算预测英超夺冠概率:利物浦60.3%,曼城34.3%
债务重组的实质是什么
酸菜鱿鱼,酸爽入味,海岛美味的享受
宇宙机器人斩获TGA多项大奖,震撼成就引发热议
草莓价格暴跌至2元一斤!这场供需博弈何时结束?
情绪价值:如何提升个人幸福感与社会和谐
A-Level数学考试可以用计算器吗?不同考试局有什么要求?
收益率曲线如何影响2025年股市?
补硒可以,但真莫过量!
脚踝处冷是什么原因
什么是商品退货政策
引导特殊儿童培养社交互动能力