MySQL存储过程

存储过程:

事先经过编译并存储在数据库中的一段sql语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的,思想上就是sql语言层面的代码封装与重用

特点:封装,重用 可以接收数据,也可以返回数据 减少网络交互,提高效率

创建:

sql 复制代码
craeture procedure 存储过程名称([参数列表])
begin
    sql语句;
end;    

调用:

sql 复制代码
call 名称([参数列表])

查看指定数据库的存储过程及状态信息

sql 复制代码
select * from information_schema.routines where routine_schema ='xxx';

查询某个存储过程的定义

sql 复制代码
show create procedure 存储过程名称

删除

sql 复制代码
drop procedure [if exists] 存储过程名称

注意:在命令行中,执行创建存储过程的sql时,需要通过关键字delimiter指定sql语句的结束符

sql 复制代码
表示当前sql以$$结束
delimiter $$ 

变量:

系统变量:

是mysql服务器提供的,不是用户定义的,属于服务器层面。分为全局变量(global)和会话变量(session)

查看所有系统变量

sql 复制代码
show [session|global] variables;

可以通过like模糊匹配方式查找变量

sql 复制代码
show [session|global] variables like '......';

查看指定变量的值

sql 复制代码
select @@[session|global] 系统变量名

设置系统变量

sql 复制代码
set [session|global] 系统变量名 = 值;
set @@[session|global]系统变量名 = 值;

注:

若没有指定session|global,默认session,会话变量

mysql服务重新启动后,所设置的全局参数会失效,要想不失效,可以在/etc/my.cnf中配置

用户自定义变量:

是用户根据需要自己定义的变量,用户变量不用提前声明,在用的时候直接用"@变量名"使用就可以,其作用域为当前连接

赋值

sql 复制代码
set @var_name = expr [,@var_name = expr]...;
set @var_name := expr [,@var_name = expr]...;
select @var_name := expr [,@var_name := expr]...;
select 字段名 into @var_name from 表明;

使用

sql 复制代码
select @var_name;

注:用户定义的变量无需对其进行声明或初始化,只不过获取的值为mull

局部变量:

是根据需要定义的在局部生效的变量,访问之前,需要declare声明,可以作用在存储过程内的局部变量和输入参数,局部变量的范围是在其内声明的begin......end块

声明

sql 复制代码
declare 变量名 变量类型 [default...]

赋值

sql 复制代码
set 变量名 = 值
set 变量名 = 值
select 字段 into 变量名 from 表明...;

If

语法

sql 复制代码
 if 条件 then
    ...
 elseif 条件2 then
    ...
 else
    ...
 end if;         

根据定义的分数score变量,判定当前分数对应的分数等级

score>= 85,等级为优秀

score>= 60 且 score <85,等级为及格

Score < 60,等级为不及格

参数

In 作为输入,调用时传入值 默认

Out 输出,作为返回值

Inout 即可做输入,也可做输出

用法

sql 复制代码
create procedure 存储过程名称([in/out/inout 参数名 参类型])
begin
    sql语句
end;    

将传入的200分制的分数,进行换算,换算成百分制,然后返回分数

case

用法

sql 复制代码
第一种
case case_value
    when when_value1 then statement_list1
    [when when_value2 then statement_list2]...
    [else statement_list]
end case;
第二种
case
    when search_condition1 then statement_list1
    [when search_condition2 then statement_list2]...
    [else statemen_list]
end case;        

根据传入的月份,判定月份所属的季节,1-3月份,为第一季度,4-6月份,为第二季度,7-9月份,为第三季度,10-12月份,为第四季度

While

有条件的循环控制语句,满足条件后,再执行循环体中的sql语句

先判定条件,如果为true,则执行逻辑,否则,不执行逻辑

sql 复制代码
while 条件 do
    sql逻辑
end while;    

计算从1累加到n的值,n为传入的参数

Repeat

满足条件时退出循环

先执行一次逻辑,然后判定逻辑是否满足,若满足,则退出;不满足,继续下一次

sql 复制代码
repeat
    sql逻辑
    until 条件
end repeat;    

Loop

loop实现简单的循环,如果不存在sql逻辑中增加退出循环的条件,可以用其来实现简单的死循环,可以配合以下两个语句使用

leave:配合循环使用,退出循环

iterate:必须在循环体中使用,作用是跳过当前循环剩下的语句,直接进入下一次循环

sql 复制代码
[begin_label:] loop
    sql逻辑
end loop [end_label];
leave label;退出指定标记的循环体
iterate label;直接进入下一次循环    

计算从1累加到n的值,n为传入的参数值

计算从1到n之间的偶数累加的值,n为传入的参数值

游标

用来存储查询结果集的数据类型,在存储过程和函数中可以使用游标对结果集进行循环的处理,游标的使用包括游标的声明,open,fetch和close,其语法分别如下

声明游标

sql 复制代码
declare 游标名称 cursor for 查询语句;

打开游标

sql 复制代码
open 游标名称;

获取游标记录

sql 复制代码
fetch 游标名称 into 变量[,变量];

关闭游标

sql 复制代码
close 游标名称;

如图会执行出错,但是u_address中是有数据的,原因在于while中的条件为true,表中的数据为空依然会继续执行

条件处理程序

可以用来定义在流程控制结构执行过程中遇到问题时相应的处理步骤,具体语法为:

sql 复制代码
declare handler_action handler for condition_value [,condition_value]... statement;

handler_action 
    continue:继续执行当前程序
    exit:终止执行当前程序
condition_value
    sqlstate sqlstate_value:状态码,如02000
    sqlwarning:所有以01开头的sqlstate代码的简写
    not found:所有以02开头的sqlstate代码的简写
    sqlexception:所有没有被sqlwarning或not found捕获的sqlstate代码的简写    

存储函数

是有返回值的存储过程,存储函数的参数只能是in类型,具体语法如下:

sql 复制代码
create function 存储函数名称([参数列表])
returns type [characteristic...]
begin 
    --sql语句
    return...;
end;    
sql 复制代码
characteristic说明:
deterministic:相同的输入参数总是产生相同的结果
no sql:不包含sql语句
reads sql data:包含读取数据的语句,但不包含写入数据的语句
从1到n累加和
相关推荐
快来卷java32 分钟前
JVM虚拟机篇(五):深入理解Java类加载器与类加载机制
java·jvm·mysql
快来卷java2 小时前
MySQL篇(六)MySQL 分库分表:应对数据增长挑战的有效策略
数据库·mysql·oracle
IT认证通关4 小时前
金仓数据库KCM认证考试介绍【2025年4月更新】
数据库
程序猿阿伟4 小时前
《SQL赋能人工智能:解锁特征工程的隐秘力量》
数据库·人工智能·sql
冰箱里的金鱼5 小时前
MYSQL 存储引擎 和 日志
数据库
Yan-英杰6 小时前
【百日精通JAVA | SQL篇 | 第三篇】 MYSQL增删改查
java·数据库·sql
信徒_6 小时前
Mysql 中的 binlog、redolog、undolog
数据库·mysql
极限实验室6 小时前
代理 Elasticsearch 服务:INFINI Gateway VS Nginx
数据库·搜索引擎
三月七(爱看动漫的程序员)6 小时前
LLM面试题六
数据库·人工智能·gpt·语言模型·自然语言处理·llama·milvus
追光天使7 小时前
Mac 上使用 mysql -u root -p 命令,出现“zsh: command not found: mysql“?
数据库·mysql·macos