MySQL教程彻底学懂存储过程

这篇文章主要为大家介绍了MySQL系列的存储过程,文中详细的为大家解释存储过程的相关概念及用法语法,以及对存储过程的理解解析,有需要的朋友可以借鉴参考下,希望能够有所帮助

目录

  • 1、存储过程的相关概念
  • 2、存储过程的用法

    • 1)存储过程的创建语法
    • 2)对创建语法的理解
  • 3.空参的存储过程

  • 4.带in模式的存储过程

  • 5.带out模式的存储过程

  • 6.带inout模式的存储过程

  • 7.存储过程的案例解析

  • 8.存储过程的删除

  • 9.查看某个存储过程的信息

  • 10.存储过程案例考核

MySQL教程彻底学懂存储过程

1、存储过程的相关概念

什么是存储过程:
类似于java中的方法,python中的函数。

使用存储过程的好处:
1、提高代码的重用性;
2、简化操作;
3、减少了编译次数,并且减少了和数据库服务器的连接次数,提高了效率。注意:平时每执行一句sql语句,就会连接mysql服务器一次;

存储过程的含义:
一组预先编译好的sql语句的集合。

2、存储过程的用法

1)存储过程的创建语法

?

1

2

3

4

create procedure 存储过程名(参数列表)

begin

存储过程体(一组合法有效的sql语句)

end

2)对创建语法的理解

① 参数列表:参数列表包含3部分

?

1

2

3

参数模式 参数名 参数类型

例如:in stuname varchar(20)

② 参数模式分类

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

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

inout:该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值。

③ 如果存储过程体仅仅只有一句话,begin/end可以省略。

ⅰ 存储过程体中的每条sql语句的结尾,要求必须加分号。
ⅱ 存储过程的结尾,可以使用delimiter重新设置,否则都用";"会造成混淆。
语法:delimiter 结束标记
例如:delimiter $ — 表示以$作为结尾符号。

④ 存储过程的调用语法

call 存储过程名(实参列表);

3.空参的存储过程

?

1

2

3

4

5

6

7

8

9

10

11

12

13

"存储过程的整个执行过程,最好在cmd窗口中执行"

— 创建一个存储过程

delimiter $

create procedure myp()

begin

insert into admin(username,`password`)

values ("tom","1111"),("jerry","2222"),

("jalen","3333"),("rose","4444"),("tonny","5555");

end $

— 调用存储过程

call myp()$

— 查看结果。

select * from admin$

结果如下:

MySQL教程彻底学懂存储过程

4.带in模式的存储过程

MySQL教程彻底学懂存储过程

1)案例:创建存储过程实现,根据部门编号,查询对应的部门名称。

?

1

2

3

4

5

6

7

8

9

10

11

— 创建一个存储过程

delimiter $

create procedure myp2(in num int)

begin

select e.ename,d.dname

from emp e

left join dept d on e.deptno=d.deptno

where e.deptno=num;

end $

— 调用存储过程

call myp2(10)$

结果如下:

MySQL教程彻底学懂存储过程

2)案例:创建一个存储过程实现,用户是否登陆成功。

MySQL教程彻底学懂存储过程

操作如下:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

— 创建一个存储过程

delimiter $

create procedure myp3(in username varchar(10),password varchar(10))

begin

declare result int;

select count(*) into result

from admin ad

where ad.username=username

and ad.password=password;

select if(count(*) > 0,"登陆成功","登陆失败") 登陆状态;

end $

— 调用存储过程

call myp3('john','8888');

结果如下:

MySQL教程彻底学懂存储过程

5.带out模式的存储过程

MySQL教程彻底学懂存储过程

1)案例1:创建一个存储过程,根据女神姓名,返回对应的男神姓名

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

— 创建一个存储过程

delimiter $

create procedure myp4(in beautyname varchar(20),out boyname varchar(20))

begin

select b.boyname into boyname

from beauty left join boys b

on beauty.boyfriend_id=b.id

where beauty.name=beautyname;

end $

— 调用

# 重新定义一个变量@boyname接收返回值boyname。

call myp4("赵敏",@boyname)$

select @boyname$

call myp4("柳岩",@boyname)$

select @boyname$

结果如下:

MySQL教程彻底学懂存储过程

2)案例2:创建一个存储过程,根据女神名,返回对应的男神名和男神魅力值

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

— 创建一个存储过程

delimiter $

create procedure myp5(in beautyname varchar(20),out boyname varchar(20),out usercp int)

begin

select b.boyname,b.usercp into boyname,usercp

from beauty left join boys b

on beauty.boyfriend_id=b.id

where beauty.name=beautyname;

end $

— 调用

# 重新定义一个变量@boyname接收返回值boyname。

call myp5("赵敏",@boyname,@usercp)$

select @boyname,@usercp$

call myp5("柳岩",@boyname,@usercp)$

select @boyname,@usercp$

结果如下:

MySQL教程彻底学懂存储过程

6.带inout模式的存储过程

1)案例1:传入a和b两个值,最终a和b都翻倍并返回。

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

— 创建一个存储过程

delimiter $

create procedure myp6(inout a int ,inout b int)

begin

— 局部变量不用加@符号。

set a=a*2;

set b=b*2;

end $

— 调用

— 特别注意调用这一块儿。

set @m=10$

set @n=20$

call myp6(@m,@n)$

select @m,@n$

结果如下:

MySQL教程彻底学懂存储过程

7.存储过程的案例解析

1)创建存储过程或函效,实现传入用户名和密码,插入到admin表中。

2)创建储过程或函数,实现传入女神编号,返回女神名称和女神电话。

3)创建存储存储过程或函数,实现传入两个女神生日,返回大小。

1)创建存储过程或函效,实现传入用户名和密码,插入到admin表中。

?

1

2

3

4

5

6

7

8

9

10

11

— 创建一个存储过程

delimiter $

create procedure pro1(in username varchar(20),in userpwd varchar(20))

begin

insert into admin(username,`password`)

values (username,userpwd);

end $

— 调用存储过程

call pro1("鲁智深","123abc")$

select * from admin$

结果如下:

MySQL教程彻底学懂存储过程

2)创建储过程或函数,实现传入女神编号,返回女神名称和女神电话。

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

— 创建一个存储过程

delimiter $

create procedure pro2(in id int,out beautyname varchar(20),out beautyphone varchar(20))

begin

select beauty.name,beauty.phone into beautyname,beautyphone

from beauty

where beauty.id=id;

end $

— 调用存储过程

call pro2(2,@beautyname,@beautyphone)$

select @beautyname,@beautyphone$

call pro2(3,@beautyname,@beautyphone)$

select @beautyname,@beautyphone$

结果如下:

MySQL教程彻底学懂存储过程

3)创建存储存储过程或函数,实现传入两个女神生日,返回大小。

?

1

2

3

4

5

6

7

8

9

10

— 创建一个存储过程

delimiter $

create procedure pro3(in borndate1 datetime,in borndate2 datetime,out result int)

begin

select datediff(borndate1,borndate2) into result;

end $

— 调用存储过程

call pro3("1993-8-12",now(),@result)$

select @result$

结果如下:

MySQL教程彻底学懂存储过程

8.存储过程的删除

?

1

drop procedure 存储过程名;

9.查看某个存储过程的信息

MySQL教程彻底学懂存储过程

10.存储过程案例考核

1)创建存储过程或函数实现传入女神名称,返回:女神and男神,格式的字符串
如传入:小昭
返回:小昭and张无忌
2)创建存储过程或函数,根据传入的条目数和起始索引,查询beauty表的记录。

1)创建存储过程或函数,实现传入女神名称,返回:女神and男神,格式的字符串。

?

1

2

3

4

5

6

7

8

9

10

11

delimiter $

create procedure test1(in beautyname varchar(20))

begin

select concat(beauty.name,"and",boys.boyname)

from beauty left join boys

on beauty.boyfriend_id=boys.id

where beauty.name=beautyname;

end $

call test1("柳岩")$

call test1("赵敏")$

结果如下:

MySQL教程彻底学懂存储过程

2)创建存储过程或函数,根据传入的条目数和起始索引,查询beauty表的记录。

?

1

2

3

4

5

6

7

8

9

10

11

12

delimiter $

create procedure test2(in startindex int,in length int)

begin

select *

from beauty

limit startindex,length;

end $

— 每页显示3条记录

— 显示第2页

call test2(3,3)$

— 显示第3页

call test2(6,3)$

结果如下:

MySQL教程彻底学懂存储过程

以上就是mysql系列彻底学懂存储过程的详细内容,更多关于mysql存储过程的资料请关注钦钦技术栈其它相关文章!

原文链接:https://huang-tong-xue.blog.csdn.net/article/details/107396625

版权声明:本文(即:原文链接:https://www.qin1qin.com/catagory/4753/)内容由互联网用户自发投稿贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 630367839@qq.com 举报,一经查实,本站将立刻删除。

(0)
上一篇 2022-07-23 12:43:44
下一篇 2022-07-23 12:44:00

软件定制开发公司

相关阅读

发表回复

登录后才能评论
通知:禁止投稿所有关于虚拟货币,币圈类相关文章,发现立即永久封锁账户ID!