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
热门推荐
2024年中国高速公路服务区发展现状:数量稳定增长,竞争将持续演变
DDoS全球攻击趋势报告:传统防御体系已经失败
物流装车规则与技巧:高效装载,降低成本
带电粒子在电场中的直线运动
职场效率革新:用Word绘制专业思维导图的8个核心步骤与技巧
商品房预售许可证办理流程是怎样的?所需材料是什么?
墨石公园:四川甘孜的“异域星球”地质奇观
汽车ev和hev的区别,车辆ev和hev的区别
历史的尘埃——清代的军乐队
消防设施操作员考下后薪资待遇如何 工资一般多少钱
2025中国计算机专业排名出炉!顶尖院校竞争激烈,这些黑马不可小觑
十个实用职场建议,帮助你提升能力并赢得信任
初中英语语法提炼:宾语从句的引导词
生物安全管理体系文件包括哪些内容?
沃柑的功效与作用:美容养颜、润肠通便、生津止渴
管理团队如何做跟进
中国电影海外传播怎样入脑入心
光学膜专利在新材料领域的创新与应用前景如何?
我国首条量子芯片生产线投产
CMOS技术:现代数字电子的核心驱动力
破解“生活算法”,我们能为外卖快递骑手做些什么
【量子退相干现象详解】:量子位稳定性的守护之道
睡姿不对,身体遭罪!4种睡姿容易让人越睡越累,不少人中招了
燕窝食用指南:解锁最佳滋养效果的秘密
自媒体创业困难吗?项目融资视角下的挑战与解决方案
如何做好项目验收工作
石材厚度应控制在多少及石材各种厚度应用场景
滑板运动发展史:从街头文化到奥运项目
如何制作更有效的汇报PPT?如何提升PPT汇报效果?
张雪峰谈女生十大好专业:看这些专业如何助力女生职场腾飞!