数据库--存储过程

article/2025/10/3 14:42:37

介绍

对sql语句进行封装、复用
在这里插入图片描述

创建、调用

在这里插入图片描述

--存储过程
--创建
create procedure p1()
beginselect count(*) from t_test;end;--调用
call p1();

在这里插入图片描述

存储过程查看、删除

在这里插入图片描述

--查看
select * from information_schema.ROUTINES WHERE ROUTINE_SCHEMA = 'test'
SHOW create procedure p1;

在这里插入图片描述
删除

--删除
drop procedure if exists p1;

注意

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

eg:

delimiter $$

存储过程-- 变量

系统变量时mysql服务器提供,不是用户定义的,属于服务器层面。分为全局变量(GLOBAL)、会话变量(SESSION)。
在这里插入图片描述

注意这里:这样的:@@a表示系统变量名!

--查看系统变量
show variables;
show session variables;
show session variables like 'auto%';
show global variables like 'auto%';
select @@autocommit;
select @@session.autocommit;
select @@global.autocommit;--设置系统变量
set session autocommit = 1;
set global autocommit = 1;insert into test_v_1 values(4,'Tom');
commit;

存储过程–用户自定义变量

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

两个@@为系统变量,一个@为用户自定义变量!
在这里插入图片描述
用户自定义的变量无需声明或初始化,只不过获取到的置为null。
注意这里的赋值语句:可以用 =或:=,介意使用:=,因为存储过程中=既是赋值语句也是对比语句

-- 用户变量:赋值set @myname = 'itcast';
set @myage := '10';
set @mygender := '男',@myhobby := 'java';select @mycolor := 'red';
select count(*) into @mycount from t_test;-- 使用
select @myname,@myage,@mygender,@myhobby;
select @mycolor,@mycount;

存储过程–局部变量

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

在这里插入图片描述

-- 局部变量
create procedure p2()
begindeclare stu_count int default 0;select count(*) into stu_count from t_test;select stu_count;end;call p2();

存储过程–流程控制

存储过程–if

在这里插入图片描述
在这里插入图片描述

eg:

create procedure p3()
begindeclare score int default 58;declare result varchar(10);if score >= 85 thenset result := '优秀';elseif score >= 60 thenset result := '及格';elseset result := '不及格';end if;select result;end;call p3();

存储过程–参数

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

eg:

create procedure p4(in score int,out result varchar(10))
beginif score >= 85 thenset result := '优秀';elseif score >= 60 thenset result := '及格';elseset result := '不及格';end if;end;call p4(98,@result);
select @result

在这里插入图片描述

create procedure p5(inout score double)
beginset score := score * 0.5;end;set @score := 198;
call p5(@score);
select @score;

在这里插入图片描述

存储过程–case

在这里插入图片描述
在这里插入图片描述

create procedure p6(in month int)
begindeclare result varchar(10);casewhen month >= 1 and month <= 3 thenset result := '第一季度';when month >= 4 and month <= 6 thenset result := '第二季度';when month >= 7 and month <= 9 thenset result := '第三季度';when month >= 10 and month <= 12 thenset result := '第四季度';elseset result := '非法参数';end case;select concat('你输入的月份为:',month,',所属的季度为:',result);end;call p6(4);

在这里插入图片描述

存储过程–while

在这里插入图片描述
在这里插入图片描述

create procedure p7(in n int)
begindeclare total int default 0;while n>0 doset total := total +n;set n := n -1;end while;select total;
end;call p7(100);

在这里插入图片描述

存储过程–repeat

repeat第一次不管是否满足条件,都会执行,满足条件,则退出循环
在这里插入图片描述
在这里插入图片描述

create procedure p8(in n int)
begindeclare total int default 0;repeat set total := total + n;set n:= n - 1;until n < 0end repeat;select total;
end;
call p8(10);
call p8(100);

在这里插入图片描述

存储过程–loop

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

create procedure p9(in n int)
begindeclare total int default 0;sum:loopif n<= 0 thenleave sum;end if;set total := total + n;set n := n -1;end loop sum;select total;
end;
call p9(100);

在这里插入图片描述
在这里插入图片描述

create procedure p10(in n int)
begindeclare total int default 0;sum:loopif n<= 0 thenleave sum;end if;if n % 2 = 1 thenset n := n -1;iterate sum;end if;set total := total + n;set n := n -1;end loop sum;select total;
end;call p10(100);

在这里插入图片描述

存储过程–游标、条件处理程序

游标是可以存查询出来结果集的,相当于保存集合

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

注意:先声明普通变量,再声明游标

条件处理程序

在这里插入图片描述
– 条件处程序,当满足条件sql状态码为02000是触发:关闭游标,退出存储过程
declare exit handler for SQLSTATE ‘02000’ close u_cursor;

create procedure p11(in uid int)
begindeclare uname varchar(100);declare uno int;declare u_cursor cursor for select name,no from t_test where id < uid;-- 条件处程序,当满足条件sql状态码为所有以02开头的触发:关闭游标,退出存储过程declare exit handler for SQLSTATE '02000' close u_cursor;drop table if exists tb_user_pro;create table if not exists tb_user_pro(id int primary key auto_increment,name varchar(100),no varchar(100));open u_cursor;while true dofetch u_cursor into uname,uno;insert into tb_user_pro values (null,uname,uno);end while;close u_cursor;
end;call p11(10);
create procedure p12(in uid int)
begindeclare uname varchar(100);declare uno int;declare u_cursor cursor for select name,no from t_test where id < uid;-- 条件处程序,当满足条件sql状态码为02000是触发:关闭游标,退出存储过程declare exit handler for not found close u_cursor;drop table if exists tb_user_pro;create table if not exists tb_user_pro(id int primary key auto_increment,name varchar(100),no varchar(100));open u_cursor;while true dofetch u_cursor into uname,uno;insert into tb_user_pro values (null,uname,uno);end while;close u_cursor;
end;call p12(10);

在这里插入图片描述


http://chatgpt.dhexx.cn/article/Y408oJvg.shtml

相关文章

SQL Sever数据库存储过程

一、背景介绍 1.遇到存储过程 回顾之前知识&#xff0c;使用在当下&#xff08;毕业设计&#xff09; 2.了解周边知识 二、思路&方案 1.了解存储过程定义、语法、种类 2.存储过程有什么优缺点 3。存储过程与触发器和函数的联系 三、过程 1.什么是存储过程&#xff1f;…

数据库MySQL —— 存储过程

目录 一、介绍 二、基本语法 三、变量 1. 系统变量 2. 用户自定义变量 3. 局部变量 四、流程控制语句 1. if判断 2. 参数 3. case 4. 循环 4.1 while 4.2 repeat 4.3 loop 五、游标 - cursor 六、条件处理程序 - handler 七、存储函数 一、介绍 存储过…

mysql数据库之存储过程

一、存储过程简介。 存储过程是事先经过编译并存储在数据库中的一段sql语句的集合&#xff0c;调用存储过程可以简化应用开发人员的很多工作&#xff0c;减少数据在数据库和应用服务器之间的传输&#xff0c;对于提高数据处理的效率是也有好处的。 存储过程思想上很简单&…

MySQL数据库存储过程

存储过程相关命令汇总存储过程存储过程优化再说存储过程的输出参数再说WHILE 和 REPEAT循环 存储过程&#xff08;Stored Procedure&#xff09;是在大型数据库系统中&#xff0c;一组为了完成特定功能的SQL 语句集&#xff0c;存储在数据库中&#xff0c;经过第一次编译后再次…

MySQL数据库存储过程讲解与实例

存储过程简介 SQL语句需要先编译然后执行&#xff0c;而存储过程&#xff08;Stored Procedure&#xff09;是一组为了完成特定功能的SQL语句集&#xff0c;经编译后存储在数据库中&#xff0c;用户通过指定存储过程的名字并给定参数&#xff08;如果该存储过程带有参数&#x…

mysql数据库存储过程详解

1.什么是存储过程 存储过程&#xff08;Stored Procedure&#xff09;是在大型数据库系统中&#xff0c;一组为了完成特定功能的SQL 语句集&#xff0c;它存储在数据库中&#xff0c;一次编译后永久有效&#xff0c;用户通过指定存储过程的名字并给出参数&#xff08;如果该存…

MySQL中的存储过程(详细篇)

文章目录 概述优点缺点 MySQL存储过程的定义存储过程的基本语句格式存储过程的使用定义一个存储过程定义一个有参数的存储过程定义一个流程控制语句 IF ELSE定义一个条件控制语句 CASE定义一个循环语句 WHILE定义一个循环语句 REPEAT UNTLL定义一个循环语句 LOOP使用存储过程插…

跨域及cors解决跨域

1.什么是跨域 出于浏览器的同源策略限制。同源策略&#xff08;Sameoriginpolicy&#xff09;是一种约定&#xff0c;它是浏览器最核心也最基本的安全功能&#xff0c;如果缺少了同源策略&#xff0c;则浏览器的正常功能可能都会受到影响。可以说Web是构建在同源策略基础之上的…

什么是跨域?如何解决跨域?

✨ 目录 &#x1f388; 什么是跨域&#x1f388; 跨域场景&#x1f388; 解决跨域的四种方式 &#x1f388; 什么是跨域 域&#xff1a; 是指浏览器不能执行其他网站的脚本跨域&#xff1a; 它是由浏览器的 同源策略 造成的,是浏览器对 JavaScript 实施的安全限制&#xff0c;…

关于跨域后端解决跨域问题

一、为什么会有跨域 出于浏览器的同源策略限制。**同源策略&#xff08;Sameoriginpolicy&#xff09;**是一种约定&#xff0c;它是浏览器最核心也最基本的安全功能&#xff0c;如果缺少了同源策略&#xff0c;则浏览器的正常功能可能都会受到影响。同源策略会阻止一个域的ja…

什么是跨域?跨域问题怎么解决?

目录 一、什么是跨域&#xff1f; 二、为什么会出现跨域问题&#xff1f; 三、常见的跨域场景 四、跨域解决方法 1、JSONP &#xff08;1&#xff09;JSONP原理 &#xff08;2&#xff09;JSONP和AJAX对比 &#xff08;3&#xff09;JSONP优缺点 &#xff08;4&#x…

跨域的本质

简介 相信大家在做web系统开发的时候&#xff0c;都遇到过前端页面访问另一个服务器而非本服务器从而遭遇的跨域问题。跨域是个很常见的问题&#xff0c;虽然在web系统中的解决方式很简单&#xff0c;加一段耳熟能详的代码&#xff0c;或者一个注解&#xff0c;或者在某个框架中…

跨域及解决

文章目录 什么是跨域&#xff1f;Origin同源的例子不同源的例子为什么需要跨域&#xff1f;请求跨域了&#xff0c;那么请求到底发出去没有&#xff1f; 如何解决&#xff1f;1.JSONP2.corsa.简单请求b.复杂请求 3.postMessage4.websocket5.nginx6.document.domain Iframe cli…

什么是跨域?以及解决跨域的方法?

【学习什么是跨域&#xff0c;以及如何解决跨域。】 1、什么是跨域&#xff1f;&#xff08;什么是同源策略&#xff1f;&#xff09; 跨域&#xff1a; 由于浏览器的同源策略引起的&#xff0c;如果说协议、域名、端口号有任何一个不一样&#xff0c;都会引起跨域 为什么会出…

【跨域】Java后端解决跨域问题

废话不多说&#xff0c;先上完整代码 建corsConfig文件&#xff0c;copy下面内容&#xff0c;放进去 import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.web.cors.CorsConfigur…

什么是同源策略,什么是跨域,如何解决跨域

1.什么是同源策略&#xff1f; 同源策略/SOP&#xff08;Same origin policy&#xff09;是一种约定&#xff0c;由 Netscape 公司 1995 年引入浏览器&#xff0c;它是浏览器最核心也最基本的安全功能&#xff0c;现在所有支持 JavaScript 的浏览器都会使用这个策略。如果缺少…

前端解决跨域----代理跨域

跨域报错&#xff1a; CORS error 为什么会跨域 ​ 先了解跨域的概念&#xff1a;发送请求的url的协议、域名、端口三者之间任意一个与当前页面的地址不同则视为跨域。 解决跨域 vue.config.js 设置代理跨域 module.exports {devServer: {proxy: {/api: {target: "ht…

什么是跨域问题?跨域解决问题

一.为什么会出现跨域问题? 出于浏览器的同源策略限制.同源策略是一种约定,它是浏览器最核心也是最基本的安全功能,如果缺少了同源策略,则浏览器的正常的功能可能会受到影响,跨域收是Web是构建在同源策略基础上的,浏览器只是针对同源策略的一种实现,同源策略会阻止一个域的Jav…

什么是跨域及怎么解决跨域问题?

什么是跨域&#xff1f; 这篇博文解释的挺清楚&#xff0c;我直接引用 什么是跨域&#xff1f;怎么解决跨域问题&#xff1f;_L瑜-CSDN博客_跨域是什么意思 跨域&#xff0c;指的是浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的&#xff0c;是浏览器施加的安全…

VUE跨域、常用解决跨域的方法

当我们遇到请求后台接口遇到 Access-Control-Allow-Origin 时&#xff0c;那说明跨域了。 跨域是因为浏览器的同源策略所导致&#xff0c;同源策略&#xff08;Same origin policy&#xff09;是一种约定&#xff0c;它是浏览器最核心也最基本的安全功能&#xff0c;同源是指&…