前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mysql存储过程

mysql存储过程

作者头像
数据分析与统计学之美
发布2022-05-09 14:53:51
11.6K0
发布2022-05-09 14:53:51
举报

1、存储过程

1)“存储过程和函数”:类似于java中的方法,python中的函数。 2)“使用存储过程的好处”:   ① 提高代码的重用性;   ② 简化操作;   ③ 减少了编译次数,并且减少了和数据库服务器的连接次数,提高了效率。    注意:每执行一句sql语句,就会连接mysql服务器一次。 3)“存储过程的含义”:一组预先编译好的sQL语句的集合。

2、存储过程使用的相关知识点

1)创建语法
代码语言:javascript
复制
create procedure 存储过程名(参数列表)
begin
     存储过程体(一组合法有效的sql语句)
end
-- 如果【存储过程体】仅仅只有一句话,begin和end可以省略,但是不建议省略。

参数列表包含3部分内容:参数模式 参数名 参数类型,例如:in stuname varchar(20)

2)参数模式分类
  • in:该参数可以作为输入,也就是该参数,需要调用方法传入值。
  • out:该参数可以作为输出,也就是该参数,可以作为返回值。
  • inout:该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值。
3)delimiter定义存储过程的结束标记

  在mysql语句中,由于每一个语句后面必须要;结尾,而存储过程也需要一个符号结尾,为了防止混淆,我们需要在创建存储过程之前,先使用delimiter定义一个存储过程的结束标记。同时,当我们使用delimiter定义了新的结束标记后,只要是没有关闭当前窗口,之后写的sql语句,就都需要用这个新的结束标记,作为sql语句的结束标记。

代码语言:javascript
复制
-- 语法:
delimiter 结束标记
-- 表示以$符号作为存储过程的结束符号。
delimiter $
4)存储过程的调用
代码语言:javascript
复制
call 存储过程名(实参列表);

3、空参的存储过程

  • 注意:“存储过程的整个执行过程,最好在CMD窗口中执行”
代码语言:javascript
复制
-- 创建一个存储过程
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)案例一:创建存储过程,实现根据部门编号,查询对应的部门名称。

代码如下:

代码语言:javascript
复制
-- 创建一个存储过程
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)案例二:创建一个存储过程实现,用户是否登陆成功。
在这里插入图片描述
在这里插入图片描述

代码如下:

代码语言:javascript
复制
-- 创建一个存储过程
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)案例一:创建一个存储过程,根据女神名,返回对应的男神名。

代码如下:

代码语言:javascript
复制
-- 创建一个存储过程
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)案例二:创建一个存储过程,根据女神名,返回对应的男神名和男神魅力值。

代码如下:

代码语言:javascript
复制
-- 创建一个存储过程
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都翻倍并返回。

代码如下:

代码语言:javascript
复制
-- 创建一个存储过程
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表中。

代码如下:

代码语言:javascript
复制
-- 创建一个存储过程
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)创建储过程或函数,实现传入女神编号,返回女神名称和女神电话。

代码如下:

代码语言:javascript
复制
-- 创建一个存储过程
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)创建存储存储过程或函数,实现传入两个女神生日,返回大小。

代码如下:

代码语言:javascript
复制
-- 创建一个存储过程
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、存储过程的删除

  • drop procedure 存储过程名;

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

在这里插入图片描述
在这里插入图片描述

10、存储过程案例考核

在这里插入图片描述
在这里插入图片描述
1)创建存储过程或函数,实现传入女神名称,返回:女神AND男神,格式的字符串。

代码如下:

代码语言:javascript
复制
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表的记录。

代码如下:

代码语言:javascript
复制
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)$

效果如下:

在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-12-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、存储过程
  • 2、存储过程使用的相关知识点
    • 1)创建语法
      • 2)参数模式分类
        • 3)delimiter定义存储过程的结束标记
          • 4)存储过程的调用
          • 3、空参的存储过程
          • 4、带in模式的存储过程
            • 1)案例一:创建存储过程,实现根据部门编号,查询对应的部门名称。
              • 2)案例二:创建一个存储过程实现,用户是否登陆成功。
              • 5、带out模式的存储过程
                • 1)案例一:创建一个存储过程,根据女神名,返回对应的男神名。
                  • 2)案例二:创建一个存储过程,根据女神名,返回对应的男神名和男神魅力值。
                  • 6、带inout模式的存储过程
                    • 1)案例1:传入a和b两个值,最终a和b都翻倍并返回。
                    • 7、存储过程的案例解析
                      • 1)创建存储过程或函效,实现传入用户名和密码,插入到admin表中。
                        • 2)创建储过程或函数,实现传入女神编号,返回女神名称和女神电话。
                          • 3)创建存储存储过程或函数,实现传入两个女神生日,返回大小。
                          • 8、存储过程的删除
                          • 9、查看某个存储过程的信息
                          • 10、存储过程案例考核
                            • 1)创建存储过程或函数,实现传入女神名称,返回:女神AND男神,格式的字符串。
                              • 2)创建存储过程或函数,根据传入的条目数和起始索引,查询beauty表的记录。
                              相关产品与服务
                              对象存储
                              对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
                              领券
                              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档