Mysql存储过程与存储函数

文章目录

    • 1. 简介
    • 2. 存储过程的特点
    • 3. 存储过程操作语法
    • 4. 存储过程变量
    • 5. 其它语法
    • 6. 存储函数

1. 简介

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

2. 存储过程的特点

  • 封装和复用
  • 可以接受参数,也可以返回数据
  • 减少网络交互,效率提升

3. 存储过程操作语法

  • 创建存储过程
create procedure 存储过程名称([参数列表])
begin
-- sql语句
end;call 名称 ([参数]);

下面创建一个存储过程p1

create procedure p1()
beginselect count(*) from 用户表;
end;

在这里插入图片描述

下面调用上面的存储过程

call p1;

在这里插入图片描述

  • 查看存储过程

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

select * from information_schema.routines  where routine_schema='数据库名称';
-- 使用
select * from information_schema.routines  where routine_schema='Mysql_learn';

在这里插入图片描述

查询某个存储过程的定义

show create procedure 存储过程名称;
--使用
show create procedure p1;

在这里插入图片描述

  • 删除存储过程
drop procedure [if exists] 存储过程名称;

注意:在命令行中执行创建存储过程的语法时可能会出现问题,因为命令行默认';'就结束sql语句,所以我们要通过关键字delimiter指定sql语句的结束符

delimiter $$;

4. 存储过程变量

  • 系统变量

系统变量指的是Mysql服务器提供,不是用户定义的,属于服务器层面。分为全局变量(Global,所有会话有效)和会话变量(SESSION)

查看系统变量

-- 查看所有系统变量(默认为session级别)
show [session|global] variables;
-- 可以通过like模糊匹配的方式查找变量
show [session|global] variables like '....';
-- 查看指定变量的值
select @@[session|global].系统变量名;

在这里插入图片描述

设置系统变量

set [session|global] 系统变量名=;
set  @@[session|global] 系统变量名=;
  • 用户自定义变量

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

赋值

set @var_name= expr [, @var_name=expr]...;
set @var_name :=expr...;
select @var_name :=expr ....;
select 字段名 into @var_name from 表名;

使用

select @var_name;
set @my_name :="你好";
select @my_name;

在这里插入图片描述

  • 局部变量

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

声明

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

变量类型就是数据库字段类型:int、bigint、char、varchar、date、time等

赋值

set 变量名=;
set 变量名:=;
select 字段名 into 变量名 from 表名;

5. 其它语法

  • if
if 条件1 then
....
elseif 条件2 then
...
else
...
end if;
  • 参数
类型含义备注
IN该类参数作为输入,也就是需要调用时传入值默认
OUT该类参数作为输出,也就是该参数可以作为返回值
INOUT既可以作为输入又可以作为输出
create procedure 名称([in/out/inout 参数名 参数类型])
beginend;
create procedure p2(in score int ,out result varchar(10))
begin
if score > 18 thenset result := '优秀';
elseif score > 60 then set result := '及格';
else set result := '不及格';
end if;
end;call p2(68,@result);
select @result;

在这里插入图片描述

  • case

语法一

case case_valuewhen when_value1 then statement_list1;.....else statement_list;
end case;
create procedure p3(in season int ,out result varchar(10))
begincase when season > 1 and season <= 3 then set result :="第一季度";when season > 4 and season <= 6  then set result :="第二季度";when season > 7 and season <= 9 then set result :="第三季度";when season > 10 and season <= 12 then set result :="第四季度";else set result :="月份不符合标准";end case;
end;call p3(12,@result);
select @result;

在这里插入图片描述

语法二

casewhen serch_condition1 then statement_list......else statement_list
end case;
  • while循环
while 条件 DOend while;
  • repeat循环

repeat 时有条件的循环控制语句,当满足条件的时候推出循环

repeatsql 逻辑until 条件
end repeat
create procedure p4(in n int)
begindeclare total int default 0;repeat set total := total+n;set n :=n -1;until n<=0end repeat;select total as '累加和';
end;call p4(14);

在这里插入图片描述

  • loop循环

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

  • leave:配合循环使用,退出循环
  • iterate:必须在循环中,作用时跳出当前循环剩下的语句,直接进入下一个循环
[begin_label:] loopend loop [end_label];
leave label; --退出指定标记的循环体
iterate label; --直接进入下一次循环
CREATE DEFINER=`root`@`localhost` PROCEDURE `p5`(in n int)
begindeclare total int default 0;sum: loopif n<=0 then leave sum;end if;set total := total+n;set n :=n-1;end loop sum;SELECT total;
end;
call p5(14);

在这里插入图片描述

  • 游标

游标(CURSOR)是用来存储查询结果集的数据类型,在存储过程和函数中可以使用游标对结果集进行循环处理。游标的使用包括游标的声明、Open、Fetch和Close,其语法分别如下:

声明

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

打开游标

open 游标名称;

获取游标记录

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

关闭游标

close 游标名称;
  • 条件处理程序

条件处理程序(handler)可以用来在流程控制结构执行过程中遇到的问题时相应的处理步骤。具体的语法为:

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

create procedure p6(in uage int)
begin-- 普通变量要在游标之前声明declare u_id int;declare u_name varchar(100);declare u_age int;declare u_cursor cursor for select 用户ID,姓名,年龄 from 用户表 where 年龄 < uage; declare exit handler for SQLSTATE '02000' close u_cursor;drop table if exists tb_user;create table if not exists tb_user(id int primary key auto_increment,user_id int not null,user_name varchar(100),user_age  int);open u_cursor;-- 这里使用条件处理程序来解决游标遍历完后结束循环的问题while true dofetch u_cursor into u_id,u_name,u_age;insert into tb_user values(null,u_id,u_name,u_age);end while;
end;call p6(27);

在这里插入图片描述

6. 存储函数

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

create function 存储函数名称([参数列表])
returns type [characteristic...]
begin return ...,
end;

characteristic说明:

  • deterministic:相同的输入参数总是产生相同的结果
  • no sql:不包含sql语句
  • reads sql date:包含读取数据的语句,但不包含写入数据的语句
-- 从1到n的累加
create function fun1(n int)
returns int deterministic
begindeclare total int default 0;while n>0 doset total :=total+n;set n :=n-1;end while;return total;
end;

在这里插入图片描述

select fun1(14);

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/72569.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vs2019 c++开发linux应用

VS2019 C的跨平台开发——Linux开发_Mr_L_Y的博客-CSDN博客前言由于前段时间正好买了一个服务器来跑Tensorflow的推理模型&#xff0c;所以借这个机会把Linux的开发也一并补上。先声明我的服务器是Ubuntu16.04&#xff0c;下面文章的内容也是基于Ubuntu16.04的。为什么标题要写…

MySQL——连接查询

2023.9.4 连接查询相关sql92语句笔记&#xff1a; #连接查询。 又称多表查询&#xff0c;当查询的字段来自多个表时&#xff0c;就会用到连接查询。 #等值连接 /* ①多表等值连接的结果为多表的交集部分 ②n表连接&#xff0c;至少需要n-1个连接条件 ③多表的顺序没有要求 ④一…

论文阅读《Nougat:Neural Optical Understanding for Academic Documents》

摘要 科学知识主要存储在书籍和科学期刊中&#xff0c;通常以PDF的形式。然而PDF格式会导致语义信息的损失&#xff0c;特别是对于数学表达式。我们提出了Nougat&#xff0c;这是一种视觉transformer模型&#xff0c;它执行OCR任务&#xff0c;用于将科学文档处理成标记语言&a…

数据结构之栈的实现(附源码)

目录 一、栈的概念及结构 ​二、栈的实现 三、初学栈的练习题 一、栈的概念及结构 栈&#xff1a;一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶&#xff0c;另一端称为栈底。栈中的数据元素遵守后进先出…

JS数组迭代方法实操

数组迭代方法有 1. every() 2.some() 3.foreach() 4.map() 5.filter 逐一操作&#xff0c;并简要区分之。 1 every() every() 方法使用指定的函数测试数组中所有的项&#xff0c;在数组的所有项都满足该条件时&#xff0c;才返回true&#xff0c;否则返回false&#xff1b; …

Win10下使用vim9

作为一个经常与文字打交道的Writer&#xff0c;你在学会Vim的基本操作之后&#xff0c;就一定会爱上Vim的。 以下是Windows10_64位&#xff08;专业版&#xff09;环境中安装、使用Vim9的全过程&#xff0c;分享一下&#xff1a; 一、下载、安装Vim9 去Vim官网去下载最新的Vi…

切片机制和MR工作机制

InputFormat基类 TextInputFormat&#xff1a;TextInputFormat是默认的FileInputFormat实现类。按行读取每条记录。键是存储该行在整个文件中的起始字节偏移量&#xff0c; LongWritable类型。 CombineTextInputFormat&#xff1a;CombineTextInputFormat用于小文件过多的场景…

React原理 - React Reconciliation-上

目录 扩展学习资料 React Reconciliation Stack Reconciler【15版本、栈协调】 Stack Reconciler-事务性 事务性带来的弊端&#xff1a; 扩展学习资料 名称 链接 备注 官方文档 Reconciliation – React 英文 stack reconciler Implementation Notes – React 英文…

Ubuntu22.04安装Mongodb7.0

Ubuntu安装Mongodb 1.平台支持2.安装MongoDB社区版2.1导入包管理系统使用的公钥2.2为MongoDB创建列表文件2.3重新加载本地包数据库2.4安装MongoDB包1.安装最新版MongoDB2.安装指定版MongoDB 3.运行MongoDB社区版1.目录2.配置文件3.初始化系统4.启动MongoDB5.验证MongoDB是否成功…

Python的pandas库来实现将Excel文件转换为JSON格式的操作

✅作者简介&#xff1a;2022年博客新星 第八。热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏…

物联网应用中蓝牙模块怎么选?_蓝牙模块厂家

在蓝牙模块选型前期&#xff0c;一定要了解应用场景以及需要实现的功能&#xff08;应用框图&#xff09;&#xff0c;以及功能实现过程中所能提供调用的接口&#xff08;主从设备&#xff0c;功能&#xff09;&#xff0c;考虑模块供电&#xff0c;尺寸&#xff0c;接收灵敏度…

【已更新建模代码】2023数学建模国赛B题matlab代码--多波束测线问题

一、 问题重述 1.1问题背景 海洋测深是测定水体深度与海底地形的重要任务&#xff0c;有两种主要技术&#xff1a;单波束测 深与多波束测深。单波束适用于简单任务&#xff0c;但多波束可提供更精确的地形数据。多 波束系统的关键在于覆盖宽度与重叠率的设计&#xff0c;以确保…

【JavaSE】面试01

文章目录 1. JDK、JRE、JVM之间的关系2. 补充3. 面试题&#xff1a;重载和重写的区别&#xff1f;4. super和this5. &#xff08;重点&#xff01;&#xff01;&#xff09;若父类和子类均有静态代码块、实例代码块以及无参构造方法&#xff0c;则继承关系上的执行顺序&#xf…

RK3588平台产测之ArmSoM-W3 DDR压力测试

1. 简介 RK3588从入门到精通 ArmSoM团队在产品量产之前都会对产品做几次专业化的功能测试以及性能压力测试&#xff0c;以此来保证产品的质量以及稳定性 优秀的产品都要进行多次全方位的功能测试以及性能压力测试才能够经得起市场的检验 2. 环境介绍 硬件环境&#xff1a; …

Hadoop生态之hive

一 概述与特点 之所以把Hive放在Hadoop生态里面去写,是因为它本身依赖Hadoop。Hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供类 SQL 查询功能。 其本质是将 SQL 转换为 MapReduce/Spark 的任务进行运算,底层由 HDFS 来提供…

JavaExcel:自动生成数据表并插入数据

故事背景 出于好奇&#xff0c;当下扫描excel读取数据进数据库 or 导出数据库数据组成excel的功能层出不穷&#xff0c;代码也是前篇一律&#xff0c;poi或者easy excel两种SDK的二次利用带来了各种封装方法。 那么为何不能直接扫描excel后根据列的属性名与行数据的属性建立S…

基于JAVA SSM框架和JSP的超市小卖部管理系统设计

摘要 随着时代的发展&#xff0c;传统的超市购物方式已经不能满足人们的需求&#xff0c;对于顾客来说&#xff0c;排队购物和支付购物费用的问题亟待解决。对于实体超市来说&#xff0c;他们面临着网上购物的竞争压力&#xff0c;作为超市经理&#xff0c;他们要降低成本&…

如何自启动MySQL服务与解决MySQL字符集问题

1、自启动mysql服务 &#xff08;1&#xff09;查看mysql是否自启动&#xff08;默认自启动&#xff09; systemctl list-unit-files|grep mysqld.service &#xff08;2&#xff09;如不是enabled可以运行如下命令设置自启动 systemctl enable mysqld.sercice2、字符集…

SpringBoot 博客网站

SpringBoot 博客网站 系统功能 登录注册 博客列表展示 搜索 分类 个人中心 文章分类管理 我的文章管理 发布文章 开发环境和技术 开发语言&#xff1a;Java 使用框架: SpringBoot jpa H2 Spring Boot是一个用于构建Java应用程序的开源框架&#xff0c;它是Spring框架的一…

Unity——脚本与导航系统

Unity内置了一个比较完善的导航系统&#xff0c;一般称为Nav Mesh&#xff08;导航网格&#xff09;&#xff0c;用它可以满足大多数游戏中角色自动导航的需求。 一、导航系统相关组件 Unity的导航系统由以下几个部分组成&#xff1a; Nav Mesh。Nav Mesh与具体的场景关联&…