MySQL存储过程

ops/2025/1/17 18:32:31/

存储过程:

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

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

创建:

craeture procedure 存储过程名称([参数列表])
beginsql语句;
end;    

调用:

call 名称([参数列表])

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

select * from information_schema.routines where routine_schema ='xxx';

查询某个存储过程的定义

show create procedure 存储过程名称

删除

drop procedure [if exists] 存储过程名称

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

表示当前sql以$$结束
delimiter $$ 

变量:

系统变量:

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

查看所有系统变量

show [session|global] variables;

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

show [session|global] variables like '……';

查看指定变量的值

select @@[session|global] 系统变量名

设置系统变量

set [session|global] 系统变量名 = 值;
set @@[session|global]系统变量名 = 值;

注:

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

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

用户自定义变量:

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

赋值

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 表明;

使用

select @var_name;

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

局部变量:

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

声明

declare 变量名 变量类型 [default...]

赋值

set 变量名 = 值
set 变量名 = 值
select 字段 into 变量名 from 表明...;

If

语法

 if 条件 then...elseif 条件2 then...else...end if;         

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

score>= 85,等级为优秀

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

Score < 60,等级为不及格

参数

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

Out 输出,作为返回值

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

用法

create procedure 存储过程名称([in/out/inout 参数名 参类型])
beginsql语句
end;    

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

case

用法

第一种
case case_valuewhen when_value1 then statement_list1[when when_value2 then statement_list2]...[else statement_list]
end case;
第二种
casewhen 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,则执行逻辑,否则,不执行逻辑

while 条件 dosql逻辑
end while;    

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

Repeat

满足条件时退出循环

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

repeatsql逻辑until 条件
end repeat;    

Loop

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

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

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

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

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

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

游标

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

声明游标

declare 游标名称 cursor for 查询语句;

打开游标

open 游标名称;

获取游标记录

fetch 游标名称 into 变量[,变量];

关闭游标

close 游标名称;

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

条件处理程序

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

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

存储函数

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

create function 存储函数名称([参数列表])
returns type [characteristic...]
begin --sql语句return...;
end;    
characteristic说明:
deterministic:相同的输入参数总是产生相同的结果
no sql:不包含sql语句
reads sql data:包含读取数据的语句,但不包含写入数据的语句
从1到n累加和


http://www.ppmy.cn/ops/150886.html

相关文章

爬虫案例:python爬取京东商品数据||京东商品详情SKU价格

网址&#xff1a;https://www.jd.com/ 基于当下的淘宝网站反扒机制太严格&#xff0c;即使通过模拟浏览来获取&#xff0c;依旧比较难&#xff0c;因此选择京东这个平台来练习一下通过模拟浏览器来进行数据获取。 1、爬取思路 &#xff08;1&#xff09;本次爬取的内容为京东…

Vulnhub DC-8靶机攻击实战(一)

导语   Vulnhub DC-8靶机教程来了,好久没有更新打靶的教程了,这次我们在来更新一期关于Vulnhub DC-8的打靶训练,如下所示。 安装并且启动靶机 安装并且启动靶机,如下所示。 开始信息采集 进入到Kali中,通过如下的命令来查找到靶机的IP地址。 arp-scan -l根据上面的结…

【Web】Web API 简介

API API (application programming interface) 是一种软件接口&#xff0c;为调用方提供服务和功能&#xff0c;而调用方无需知道实现细节。 这是一个抽象概念&#xff0c;如果举例说明&#xff0c;那就是在餐厅拿菜单点餐&#xff0c;菜单就是餐厅给客户的 API&#xff0c;我…

C#局部函数 VS Lambda表达式

一、引言 在 C# 的编程世界里&#xff0c;我们常常会遇到各种实现功能的方式&#xff0c;其中 Lambda 表达式和局部函数都是非常强大的特性。Lambda 表达式自诞生以来&#xff0c;凭借其简洁的语法和强大的功能&#xff0c;深受广大开发者的喜爱&#xff0c;尤其是在处理集合操…

基于unity的多人家装应用的设计与实现

摘要 本课题根据主流家装应用存在的问题和结合了Unity3D引擎所具有的优势,在主流家装应用的基础上弥补了常见的缺憾,实现了一种新型的交互更强的家装展示系统。 本系统主要通过将家具模型资源和材质等资源导入Unity3D平台中,通过C#代码开发,搭建UGUI框架,实现室内漫游、家…

用 Python 从零开始创建神经网络(二十二):预测(Prediction)/推理(Inference)(完结)

预测&#xff08;Prediction&#xff09;/推理&#xff08;Inference&#xff09;&#xff08;完结&#xff09; 引言完整代码&#xff1a; 引言 虽然我们经常将大部分时间花在训练和测试模型上&#xff0c;但我们这样做的核心原因是希望有一个能够接受新输入并生成期望输出的…

中间件以及主流中间件产品:IBM MQSeries和BEA Tuxedo介绍

中间件简介 中间件(Middleware)是一类位于操作系统和应用程序之间的软件层,负责提供通用服务,简化分布式系统开发和集成。中间件的目标是屏蔽底层操作系统和网络的复杂性,为应用程序提供统一的接口和支持。 中间件的功能 消息传递:提供可靠的消息队列服务,支持异步通信…

如何选择合适的服务器?服务器租赁市场趋势分析

服务器租赁市场概览 服务器租赁 market可以分为两种类型&#xff1a;按小时、按月和按年&#xff0c;每种模式都有其特点和适用场景&#xff0c;按小时租赁是最经济实惠的选择&#xff0c;适用于短期需求&#xff1b;按月租赁则适合中长期使用&#xff1b;而按年租赁则是最灵活…