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
热门推荐
考计算机等级证书有什么用
黄菊花的培育管理
20年封窗师傅亲授:封窗全流程实用指南
怎么判断自己有耵聍
合肥房价新走势:跌幅放缓,市场回暖可期
健康科普 | 守护健康的关键之道之如何控制血压?
“八大菜系”是怎么诞生的?一文说清其源流与演变
软件测试中的冒烟测试
粤菜啫啫煲发音为什么念jue?怎么做才能正宗好吃呢?
腰肌劳损的症状和表现有哪些
二型糖尿病患者能喝石斛水吗?专家解读其功效与注意事项
只用10分钟,一次性搞懂公钥和私钥
从《哪吒2》看数字与文化产业协同
连接财务和营销计划的资源管理战略
如何根据地层选旋挖钻头
太极桩、无极桩、混元桩解析:三种传统武术桩功详解
中山三乡:探访历史文化游径,品读改革开放故事
路况监测技术:思通数科大模型在智能交通管理中的应用
荨麻疹性血管炎要忌口哪些
芋头:一种兼具实用与观赏的植物
期货投资策略全解析:趋势跟踪、均值回归与套利策略的应用场景
钢琴入门:钢琴键盘与大谱表对照详解
做完甲状腺手术后可能会出现哪些症状?
左宗棠简介
看似“相克”的菠菜与猪肝,实则是养生绝配?
2025广东高考报名人数统计表!附广东高考人数历年统计
当兵年龄限制是多少岁?当兵一般在部队做什么?
汽车制造中使用了哪些材料?这些材料在汽车结构中的应用有何优缺点?
十世班禅活佛娶妻的相关规定(藏传佛教对十世班禅活佛娶妻的限制与要求)
喝酒导致失眠症的五种治疗方法