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
热门推荐
郁金香花海怎么拍照?4个郁金香拍花技巧,一学就会,轻松拍片!
韩国义务兵薪资曝光:揭开这个神秘的军事话题
被辞退协税员如何依法维权
设立公司所需法律文件:公司注册的必要条件
美国公司法的资本贡献规则:出资认缴制还是实缴制探讨
期货市场的资金评估战法:精确做空工业硅、玻璃
13号星期五:西方世界最著名的不祥之日
重讲一遍《海的女儿》《灰姑娘》,经典童话有了现代重构
直流电机并联电阻的作用与选择方法详解
怎么关闭家里的声控灯
老河口市文物古迹介绍
Windows Vista开发的历史:从诞生到消亡的曲折历程
敦煌人社"三精"模式 实现职业技能培训"量质齐升"
汽车三包政策解读:从基本定义到维权指南
颠覆传统!新方法,提高效率,新发Nature子刊!
如何通过八字看出一个人生地周围的环境——实用八字断例系列之003
关注企鹅病:脊髓小脑性共济失调(SCA)
办公室白领的普拉提救星,告别久坐困扰,重拾身体活力
核电设备行业系列深度报告二:可控核聚变:国内实验堆进展如何
它是蔬菜,也是水果,还是“药材”,对身体有10大作用!
2024年第1期 | 肠道菌群与儿童生长发育前沿科技研修会圆满落幕
亚刻奥特曼介绍
没时间锻炼?上班族可以试试这些!
爸妈必看!小孩黄金成长期必备补钙饮食秘诀
暖气片热传递原理详解:如何让家更温暖?
邺城遗址:开创都城规划新格局的历史名城
寻迹邺城:六朝古都的考古发现与文化价值
绝区零11号角色装备如何搭配?绝区零11角色装备推荐
八字命理与周易智慧:解读个人命运与潜能
燕麦粥的营养价值及功效