MySQL教程彻底学懂存储过程

吾爱主题 阅读:184 2024-04-02 08:06:34 评论:0
目录
  • 1、存储过程的相关概念
  • 2、存储过程的用法
    • 1)存储过程的创建语法
    • 2)对创建语法的理解
  • 3.空参的存储过程
  • 4.带in模式的存储过程
  • 5.带out模式的存储过程
  • 6.带inout模式的存储过程
  • 7.存储过程的案例解析
  • 8.存储过程的删除
  • 9.查看某个存储过程的信息
  • 10.存储过程案例考核

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$

结果如下:

4.带in模式的存储过程

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)$

结果如下:

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

操作如下:

?
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' );

结果如下:

5.带out模式的存储过程

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$

结果如下:

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$

结果如下:

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$

结果如下:

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$

结果如下:

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$

结果如下:

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$

结果如下:

8.存储过程的删除

?
1 drop procedure 存储过程名;

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

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( "赵敏" )$

结果如下:

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存储过程的资料请关注服务器之家其它相关文章!

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

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容