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
相关推荐
weisian15123 分钟前
Mysql--实战篇--@Transactional失效场景及避免策略(@Transactional实现原理,失效场景,内部调用问题等)
数据库·mysql
AI航海家(Ethan)27 分钟前
PostgreSQL数据库的运行机制和架构体系
数据库·postgresql·架构
Kendra9193 小时前
数据库(MySQL)
数据库·mysql
时光书签4 小时前
Mongodb副本集群为什么选择3个节点不选择4个节点
数据库·mongodb·nosql
人才程序员6 小时前
【C++拓展】vs2022使用SQlite3
c语言·开发语言·数据库·c++·qt·ui·sqlite
极客先躯6 小时前
高级java每日一道面试题-2025年01月23日-数据库篇-主键与索引有什么区别 ?
java·数据库·java高级·高级面试题·选择合适的主键·谨慎创建索引·定期评估索引的有效性
指尖下的技术6 小时前
Mysql面试题----MyISAM和InnoDB的区别
数据库·mysql
永远是我的最爱7 小时前
数据库SQLite和SCADA DIAView应用教程
数据库·sqlite
指尖下的技术7 小时前
Mysql面试题----为什么B+树比B树更适合实现数据库索引
数据结构·数据库·b树·mysql
Ciderw7 小时前
MySQL为什么使用B+树?B+树和B树的区别
c++·后端·b树·mysql·面试·golang·b+树