mysql基础---存储过程和函数

存储过程和函数
好处:
1.提高代码的重用性
2.简化操作

存储过程
含义:一组预先编译好的sql语句的集合,理解成批处理语句
1.提高代码的重用性
2.简化操作
3.减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率

一.创建语法
CREATE PROCEDURE 存储过程名(参数列表)
BEGIN
存储过程体(一组合法的sql语句)
END

注意:
1.参数列表包含三部分
参数模式 参数名 参数类型
举例:
in stuname varchar(20)

参数模式:
in: 该参数可以作为输入,也就是该参数需要调用方传入值;
out:输出,作为返回值;
INOUT:既可以作为输入又可以作为输出;

2.如果存储过程体仅仅只有一句话,begin end可以省略
存储过程体中的每条sql语句的结尾要求必须加分号。
存储过程的结尾可以使用delimiter 重新设置。
语法:
delimiter 结束标记

案例:
delimiter $;

二.调用语法
CALL 存储过程名(实参列表);

#案例1.空参列表的存储过程
#案例:插入到major表中五条记录

#先查看一下这个表的数据

SELECT * FROM major;
delimiter $
CREATE PROCEDURE pro_mj1()
BEGIN
			INSERT INTO major(majorname)
			VALUES('c++'),('php'),('ios'),('mysql'),('goland');
END $

#调用上面的存储过程
CALL pro_mj1()$

#2.创建带in模式参数的存储过程
#案例1:创建存储过程实现,根据女神名,查询对应的男神信息

delimiter $
CREATE PROCEDURE get_boy_by_girl_2(in beautyName VARCHAR(30))
BEGIN
		SELECT bo.*
		FROM boys bo
		RIGHT JOIN beauty b ON bo.id=b.boyfriend
		WHERE b.name = beautyName;
END $

在这里插入图片描述
#调用存储函数 get_boy_by_girl
CALL get_boy_by_girl(‘女帝’)$

#案例2.创建存储过程,实现判断用户是否登录

CREATE PROCEDURE isLogin(in username VARCHAR(20),in PASSWORD VARCHAR(20))
BEGIN
DECLARE result int(10) DEFAULT 0;#声明局部变量并初始化

	SELECT COUNT(*) INTO result#将结果赋值局部变量
	FROM admin
	WHERE admin.username=username 
	AND admin.password=PASSWORD;

	SELECT IF(result > 0,'登录成功','登录失败'); #打印结果,调用变量

end $

#调用存储过程isLogin
call isLogin(‘zhangsan’,‘123456’)$

#3.创建带out模式的存储过程
#案例1:根据女神名,返回对应的男神名
create PROCEDURE getBoysName(in girlName VARCHAR(20),OUT boyName VARCHAR(20))
BEGIN
SELECT bo.boy_name INTO boyName #赋值给输出参数
from boys bo
RIGHT JOIN beauty b ON bo.id = b.boyfriend
WHERE b.name= girlName;
END $

#调用存储过程getBoysName
#定义用户变量接收存储过程返回值:

#写法1:
SET @bName$
CALL getBoysName(‘娜美’,@bName)$

#写法2:不用单独定义用户变量,直接用
CALL getBoysName(‘娜美’,@bName)$
SELECT @bName$

#案例2.根据女神名,返回对应的男神名和男神魅力值

CREATE PROCEDURE getBoysInfo(in girlName VARCHAR(20),out boyName VARCHAR(20),out userCp INT(10))
BEGIN
		SELECT bo.boy_name,bo.user_cp INTO boyName,userCp
		from boys bo
		RIGHT JOIN beauty b ON bo.id = b.boyfriend
		WHERE b.`name`= girlName;
END $

CALL getBoysInfo('娜美',@bName,@userCp)$
SELECT @bName,@userCp$

#4.创建带inout模式参数的存储过程
#案例1:传入a和b两个值,最终a和b都翻倍并返回
CREATE PROCEDURE useInout(INOUT a int(10),INOUT b int(10))
BEGIN
#为存储过程的输出参数赋值,相当于为用户变量赋值
set a=a2;
SET b=b
2;
END $

#调用
#定义用户变量,并赋初始值

SET @m=10$
SET @n=20$
CALL useInout(@m,@n)$

SELECT @m,@n$

二.删除存储过程(这个操作可以在客户端执行):
语法:drop PROCEDURE 存储过程名;

DROP PROCEDURE pro_mj1;

三.查看存储过程的信息

show CREATE PROCEDURE isLogin;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值