目录

1、存储过程的相关概念

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

2、存储过程的用法

1)存储过程的创建语法

create procedure 存储过程名(参数列表)
begin存储过程体(一组合法有效的sql语句)
end

2)对创建语法的理解

① 参数列表:参数列表包含3部分
参数模式   参数名   参数类型例如:in  stuname  varchar(20)
② 参数模式分类
in:该参数可以作为输入,也就是该参数,需要调用方传入值。out:该参数可以作为输出,也就是该参数,可以作为返回值。inout:该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值。
③ 如果存储过程体仅仅只有一句话,begin/end可以省略。
Ⅰ 存储过程体中的每条sql语句的结尾,要求必须加分号。Ⅱ 存储过程的结尾,可以使用delimiter重新设置,否则都用";"会造成混淆。
语法:delimiter 结束标记
例如:delimiter $  -- 表示以$作为结尾符号。
④ 存储过程的调用语法
call 存储过程名(实参列表);

3.空参的存储过程

"存储过程的整个执行过程,最好在CMD窗口中执行"
-- 创建一个存储过程
delimiter $
create procedure myp()
begininsert into admin(username,`password`)values ("tom","1111"),("jerry","2222"),("jalen","3333"),("rose","4444"),("tonny","5555");
end $
-- 调用存储过程
call myp()$
-- 查看结果。
select * from admin$

结果如下:

4.带in模式的存储过程

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

-- 创建一个存储过程
delimiter $
create procedure myp2(in num int)
beginselect e.ename,d.dnamefrom emp e left join dept d on e.deptno=d.deptnowhere e.deptno=num;
end $
-- 调用存储过程
call myp2(10)$

结果如下:

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


操作如下:

-- 创建一个存储过程
delimiter $
create procedure myp3(in username varchar(10),password varchar(10))
begin declare result int;select count(*) into resultfrom admin adwhere ad.username=usernameand ad.password=password;select if(count(*) > 0,"登陆成功","登陆失败") 登陆状态;
end $
-- 调用存储过程
call myp3('john','8888');

结果如下:

5.带out模式的存储过程

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

-- 创建一个存储过程
delimiter $
create procedure myp4(in beautyName varchar(20),out boyName varchar(20))
begin select b.boyName into boyNamefrom beauty left join boys bon beauty.boyfriend_id=b.idwhere beauty.name=beautyName;
end $
-- 调用
# 重新定义一个变量@boyname接收返回值boyName。
call myp4("赵敏",@boyname)$
select @boyname$call myp4("柳岩",@boyname)$
select @boyname$

结果如下:

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

-- 创建一个存储过程
delimiter $
create procedure myp5(in beautyName varchar(20),out boyName varchar(20),out userCP int)
begin select b.boyName,b.userCP into boyName,userCPfrom beauty left join boys bon beauty.boyfriend_id=b.idwhere 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都翻倍并返回。

-- 创建一个存储过程
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表中。

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

-- 创建一个存储过程
delimiter $
create procedure pro2(in id int,out beautyName varchar(20),out beautyPhone varchar(20))
beginselect beauty.name,beauty.phone into beautyName,beautyPhonefrom beautywhere beauty.id=id;
end $-- 调用存储过程
call pro2(2,@beautyname,@beautyphone)$
select @beautyname,@beautyphone$call pro2(3,@beautyname,@beautyphone)$
select @beautyname,@beautyphone$

结果如下:

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

-- 创建一个存储过程
delimiter $
create procedure pro3(in borndate1 datetime,in borndate2 datetime,out result int)
beginselect datediff(borndate1,borndate2) into result;
end $-- 调用存储过程
call pro3("1993-8-12",now(),@result)$
select @result$

结果如下:

8.存储过程的删除

drop procedure 存储过程名;

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

10.存储过程案例考核

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

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

delimiter $
create procedure test1(in beautyname varchar(20))
beginselect concat(beauty.name,"AND",boys.boyName)from beauty left join boyson beauty.boyfriend_id=boys.idwhere beauty.name=beautyname;
end $call test1("柳岩")$
call test1("赵敏")$

结果如下:

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

delimiter $
create procedure test2(in startIndex int,in length int)
beginselect *from beautylimit startIndex,length;
end $
-- 每页显示3条记录
-- 显示第2页
call test2(3,3)$
-- 显示第3页
call test2(6,3)$

结果如下:

  

   

关注微信公众号『数据分析与统计学之美』,后台回复"入群" 拉你进群哦,气氛很好滴呀!

带你学MySQL系列 | “存储过程”学不会,那是你没有看这篇文章!相关推荐

  1. 带你学MySQL系列 | 什么是数据定义语言(DDL)呢?

    如果你是刚刚学习MySQL的小白,在你看这篇文章之前,请先看看下面这些文章.有些知识你可能掌握起来有点困难,但请相信我,按照我提供的这个学习流程,反复去看,肯定可以看明白的,这样就不至于到了最后某些知 ...

  2. 带你学MySQL系列 | 困扰MySQL初学者的分组聚合查询,我终于讲明白了!

    1.分组查询的原理图 对上述原始数据,按照DEPARTMENT_ID(员工id)分组统计SALARY(薪水)的平均值. 上述原理写成代码,应该怎么写呢? select department_id,av ...

  3. 咸鱼带你学MySQL—MySQL的介绍

    目录 一.MySQL的背景 二.MySQL的优点 三.MySQL的安装 四.MySQL服务的启动和停止 1.通过命令行 2.通过计算机管理方式 五.MySQL服务的登录和退出 1.登录 2.退出 六. ...

  4. 焱老师带你学习MYSQL系列 第二篇 (MYSQL 数据结构)

    相关系列链接 焱老师带你学习MYSQL系列 第六篇 (MYSQL是如何实现锁的) 焱老师带你学习MYSQL系列 第五篇 (MYSQL事务隔离级别是如何实现的) 焱老师带你学习MYSQL系列 第四篇 ( ...

  5. 好多人都说存储过程很难?认真看这篇文章就够了

    何为存储过程? 存储过程是在数据库管理系统中保存的.预先编译的并能实现某种功能的sql程序,说直白点,java知道吧?和java的方法一样. 每遇到一个新的知识点时,我们都会看看它的优点,从而加深对它 ...

  6. 使用分层网络模型的两个优点是什么_从零开始学网络|搞懂OSI参考模型和TCP/IP分层模型,看这篇文章就够了...

    从零开始学网络|搞懂OSI参考模型和TCP/IP分层模型,看这篇文章就够了​mp.weixin.qq.com 前言 今天和大家一起谈谈"网络",之前写的文章可能不太通俗易懂,有人就 ...

  7. 女生就不适合学Java吗_女生不适合学java?给他看这篇文章,女生其实更适合学java,更好就业!...

    原标题:女生不适合学java?给他看这篇文章,女生其实更适合学java,更好就业! 女生适合学java吗?女生做IT怎么样 首先要表明我的观点,编程是不分男女,什么女生不适合学编程的说法,从客观上来说 ...

  8. 文科好应该学计算机哪类专业,文科理科分别适合哪些专业?看这篇文章就够了!...

    原标题:文科理科分别适合哪些专业?看这篇文章就够了! 如何选择一个好的学校 心仪的专业 至关重要 你想好读什么专业了吗? 学计算机就要修电脑? 学机械就是混车间? 男生喜欢什么样的? 女生都报什么专业 ...

  9. mysql root用户可以同时几个人连接_重学MySQL系列(四):10分钟快速掌握MySQL用户与权限管理

    在这篇文章中,我们来聊聊怎么管理MySQL的用户及如何为不同用户分配不同的管理权限,其实,在日常使用MySQL的过程中,这部分的工作是由DBA(数据管理员)来完成的. 而我们作为一般的开发人员,只要拿 ...

最新文章

  1. 面向对象的程序开发技术C++教学课件系列之四
  2. Spring 框架中有哪些不同类型的事件?
  3. cd : cannot create temp file for here-document: No space left on device
  4. await原理 js_「速围」Node.js V14.3.0 发布支持顶级 Await 和 REPL 增强功能
  5. mysql 时间函数大全_mysql常用的日期函数汇总
  6. ReactJs 第三章 React元素的渲染
  7. 从性能方面选择for,map和forEach
  8. 本人psp2000和psp3000都亲自试验过,没问题,刷完可以关机,能读取ISO文件,具体某些游戏可能不能运行还需要自己实践。
  9. 无条件呼叫前转接已启用
  10. 原创 | 使用JUnit、AssertJ和Mockito编写单元测试和实践TDD (六)测试哪些内容:Right-BICEP
  11. Blender 3.5 面的操作(二)
  12. 深入理解python--线程、进程与协程(1)
  13. (CVPR 2022 阅读笔记)Residual Local Feature Network for Efficient Super-Resolution
  14. ibm服务器做系统按f几,这是我的主板,请问开机启动热键按F几?
  15. php feff,php编程中要留意的那些坑~
  16. 电脑公司 ghost win7_SP1 X64 特别版 2015.05
  17. 小米无线路由器关闭WPS
  18. 【文件系统】如何在ubi之上运行squashfs
  19. Excel VBA选择文件、高容错性地打开文件
  20. 【操作指南】PPT动画大师,操作技巧汇总贴。

热门文章

  1. 【drawio笔记】向ERD表,列表和UML类添加行
  2. 微信视频使用的是什么协议?—— udp协议的介绍
  3. 新技能get,微信提现这样操作可免手续费
  4. 揭开光宇华夏高层几位伪君子炒作的真相
  5. 《奇葩说》詹青云:熬过那些日子,你才有资格过不被人左右的人生
  6. 亚马逊云科技 BuildOn 第三季 【基于 Serverless 构建零售创新应用】过程介绍及个人思考及总结
  7. zip压缩解压缩开源库-LiteZip
  8. Rapidly-Exploring Random Trees(RRT)
  9. [RK3288][Android6.0] 调试笔记 --- 调试串口的更换
  10. 聊聊C++任务定时器的设计与具体实现