MYSQL 存储过程/存储函数

简而言之,类似于封装函数

特点

基本语法

create peocedure p1()

begin

select coun(*) from studuent;

end;

call p1();

设置完别忘了把delimiter改回来

变量

系统变量

用户自定义变量

set @myname = 'its';

set @myage := 10;

局部变量

if

参数(IN,OUT,INOUT)

case

create procedure p1(in month int)

begin

declare result varchar(10);

case

when month>=1 and month <=3 then

set result := '一';

when month>=4 and month <=6 then

set result := '二';

when month>=7 and month <=9 then

set result := '三';

when month>=10 and month <=12 then

set result := '四';

else

set result := '非法';

end case;

select concat('您输入的参数为', month, '季度为',result);

end;

循环语句

while

repeat

loop

游标

但是这个有问题,while true是一直循环

可以使用Handler处理

条件处理程序Handler

刚才的程序多声明一句handler语句就可以成功退出循环

存储函数

存储函数不如存储过程,存储函数必须有返回值

相关推荐
jiayou6419 小时前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北20 小时前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12023 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip