MySQL存储过程

目录

一、概念

二、创建存储过程和调用方法

2.1创建存储过程语句

2.2调用方法

2.3参数详情

[2.4 入参存储过程](#2.4 入参存储过程)

2.5出参存储过程

2.6带有INOUT的存储过程


一、概念

根据某种需求提前写好的SQL语句集合,需要用到时调用这块集合

二、创建存储过程和调用方法

2.1创建存储过程语句

小写版

create procedure 名称([参数])

begin

内容

end;

大写版

CREATE PROCEDURE 名称([参数])

BEGIN

内容

END;

2.2调用方法

调用存储过程语句

CALL 存储过程名称([参数])

2.3参数详情

⭐⭐⭐

参数列表包括三个部分

1、参数模式 参数名 参数类型

eg: IN stuname varchar(20)

参数模式

IN : 该参数可以作为输入,也就是需要调用方传入值

OUT: 该参数作为输出,也就是该参数可以作为返回值

INOUT: 既可以作为输入参数,也可以作为输出参数

2、如果存储过程提仅仅只有一句话,那么BEGIN END 可以省略

3、存储过程中的每一条sql语句的结尾都必须加分号,需要申明结尾符号 DELIMITER 重新设置

以下在创建的过程中使用DELIMITER 开始,DELIMITER ;结束,是因为mysql是以;结束的,此处创建存储过程的时候需要指定结尾符号为,整个存储过程执行完成后,再还原为mysql的结束符;即可

复制代码
DELIMITER $
		    CREATE PROCEDURE test1()
		BEGIN
			INSERT INTO admin(username,`password`) VALUES ('JOHN1','000001');
			INSERT INTO admin(username,`password`) VALUES ('JOHN2','000002');
			INSERT INTO admin(username,`password`) VALUES ('JOHN3','000003');
			INSERT INTO admin(username,`password`) VALUES ('JOHN4','000004');
			INSERT INTO admin(username,`password`) VALUES ('JOHN5','000005');
		END $

调用

复制代码
call test1()

2.4 入参存储过程

多个参数中间用逗号隔开

复制代码
DELIMITER $
		CREATE PROCEDURE testParams(IN username varchar(20),IN password varchar(20))
		BEGIN
			DECLARE RESULT VARCHAR(20) DEFAULT '';#申明并初始化
			select COUNT(1) INTO RESULT #赋值将统计到的count(1) 赋值给RESULT结果 
			from  admin
			where admin.username=username #如果参数名相同的话指明参数是那个表的字段即可
				and admin.password=password;
		END $
		DELIMITER ;

调用

复制代码
call testParams('11','22');

2.5出参存储过程

复制代码
DELIMITER $
		CREATE PROCEDURE myp7(IN beautyName varchar(20),OUT boyName VARCHAR(20),OUT userCP varchar(20))
		BEGIN
			SELECT bo.boyName,bo.userCP INTO boyName,userCP #此处赋值的时候多个直接INTO为对应位置的出参对象即可
			FROM boys bo
				INNER JOIN beauty b on bo.id=b.boyfriend_id
			WHERE
				b.name=beautyName;
		END $
		DELIMITER ;

调用

复制代码
CALL myp7('小昭',@boyName,@userCP); 
#此处存储过程的两个入参(也即出参)用@符号定义即可,也可以先定义好传入到里面
SELECT @boyName AS boyName,@userCP as userCP #查询存储过程运行的结果

2.6带有INOUT的存储过程

复制代码
		DELIMITER $
			CREATE PROCEDURE ccgc(INOUT a int,INOUT b int)
			BEGIN
				SET a=a*2;
				SET b=b*2;
			END $
		DELIMITER ;

调用

复制代码
###此处需要提前定义参数值,类似于java的入参,
		SET @m=10;
		SET @n=30;
		call ccgc(@m,@n);
		#然后调用,并打印输出
		select @m,@n
相关推荐
流星白龙34 分钟前
【MySQL】6.MySQL基本查询(1)
数据库·windows·mysql
夕除36 分钟前
Mysql--11
数据库·mysql
❀͜͡傀儡师1 小时前
docker部署WhoDB开源轻量级数据库管理工具
数据库·docker·开源
皙然1 小时前
Redis八大核心数据类型详解:从底层实现到实战落地
数据库·redis·bootstrap
时光追逐者1 小时前
一款免费、简单、高效的在线数据库设计工具
数据库·mysql·oracle·sql server
another heaven1 小时前
【软考 2026 最新版 NoSQL 数据库全分类】
数据库·nosql
满天星83035772 小时前
【MySQL】表的操作
linux·服务器·数据库·mysql
yashuk2 小时前
Ubuntu 系统下安装 Nginx
数据库·nginx·ubuntu
F1FJJ2 小时前
VS Code 里管理 PostgreSQL,有哪些选择?主流扩展横向对比
网络·数据库·postgresql·容器
Bdygsl2 小时前
MySQL(8)—— 事务
数据库·mysql