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
热门推荐
项目管理如何编号?
合同编号规则素材大全集:法律领域中的规范与管理
全面解析家庭高速网络建设:从设备选型到科学布线的全流程指南
Mac 系统的优势和劣势是什么
猕猴桃什么时候成熟?品种、气候、栽培大揭秘!
推背图:神秘的预言与历史巧合
2025年中国低空经济应用场景分析:应用场景多元化,赋能各行各业
小儿中医理疗方法药浴
影响海运报价的主要因素有哪些?一文详解!
“口罩戴反了”是什么意思?什么梗?
与孩子聪明、诚实地谈论死亡
呕吐是什么原因造成的
国产微型车安全性能大比拼:谁是你的最佳选择?
治疗肿瘤的"隐形刀"
黑米对糖尿病患者有什么益处
如何选购一款适合自己的户外音箱?
苏联能否独立战胜德国?历史的另一种可能性
银行的信用卡额度调整的方法与规则有哪些?
全面解析翡翠品质鉴别:从颜色、透明度到工艺的全方位指南
韦特塔罗占卜要多久能学会?
数据预处理的技巧与方法提升数据质量和分析效率
如何高效获取和应用网络页面内容
USIM卡是什么?SIM卡与USIM卡哪个好?
SIM卡保护功能详解:如何保护你的手机隐私和信息安全
鱼缸尺寸参照表及选购方法
人事考勤系统在处理加班和调休时有哪些最佳实践?
林正英十大电影排行榜:重温经典,笑中带泪的僵尸传奇
化学武器:从一战滥觞到全球禁用
兔肉十大经典菜谱:从麻辣到白切,尽显各地风味
谁发明了UNO卡游戏?