MySQL教程彻底学懂存储过程
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() 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)案例:创建存储过程实现,根据部门编号,查询对应的部门名称。
-- 创建一个存储过程 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)案例:创建一个存储过程实现,用户是否登陆成功。
操作如下:
-- 创建一个存储过程 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:创建一个存储过程,根据女神姓名,返回对应的男神姓名
-- 创建一个存储过程 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:创建一个存储过程,根据女神名,返回对应的男神名和男神魅力值
-- 创建一个存储过程 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都翻倍并返回。
-- 创建一个存储过程 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)) 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)创建存储存储过程或函数,实现传入两个女神生日,返回大小。
-- 创建一个存储过程 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男神,格式的字符串
如传入:小昭
返回:小昭AND张无忌
2)创建存储过程或函数,根据传入的条目数和起始索引,查询beauty表的记录。
1)创建存储过程或函数,实现传入女神名称,返回:女神AND男神,格式的字符串。
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表的记录。
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/1073966
相关文章
- Create Procedure AtoC @ChangeMoney Money as Set Nocount ON Declare @String1 char(20) Declare @String2 char(30) ...2016-11-25
- 这篇文章主要介绍了MySQL性能监控软件Nagios的安装及配置教程,这里以CentOS操作系统为环境进行演示,需要的朋友可以参考下...2015-12-14
- 存储过程在数据库的应用中我们用到的非常的多了,下面我们来看一篇关于PHP操作MSSQL存储过程修改用户密码的例子,具体的如下所示。 mssql2008 存储过程 下面可以直接...2016-11-25
- 新版 Mysql 中加入了对 JSON Document 的支持,可以创建 JSON 类型的字段,并有一套函数支持对JSON的查询、修改等操作,下面就实际体验一下...2016-08-23
深入研究mysql中的varchar和limit(容易被忽略的知识)
为什么标题要起这个名字呢?commen sence指的是那些大家都应该知道的事情,但往往大家又会会略这些东西,或者对这些东西一知半解,今天我总结下自己在mysql中遇到的一些commen sense类型的问题。 ...2015-03-15- 这篇文章主要介绍了MySQL 字符串拆分操作(含分隔符的字符串截取),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-22
- 一、先说一下为什么要分表:当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,有可能会死在那儿了。分表的目的就在于此,减小数据库的负担,缩短查询时间。根据个人经验,mysql执行一个sql的过程如下:1...2014-05-31
- 具体详情请看下文小编给大家带来的知识点。同编写程序类似,存储过程中也有对应的条件判断,功能类似于if、switch。在MySql里面对应的是IF和CASE1、IF判断IF判断的格式是这样的:IF expression THEN commands [ELSEIF ex...2015-10-21
- 我们自己鼓捣mysql时,总免不了会遇到这个问题:插入中文字符出现乱码,虽然这是运维先给配好的环境,但是在自己机子上玩的时候咧,总得知道个一二吧,不然以后如何优雅的吹牛B。...2015-03-15
- 这几天在centos下装mysql,这里记录一下安装的过程,方便以后查阅Mysql5.5.37安装需要cmake,5.6版本开始都需要cmake来编译,5.5以后的版本应该也要装这个。安装cmake复制代码 代码如下: [root@local ~]# wget http://www.cm...2015-03-15
- 宿主机使用网线的时候,客户机在Bridged Adapter模式下,使用Atheros AR8131 PCI-E Gigabit Ethernet Controller上网没问题。 宿主机使用无线的时候,客户机在Bridged Adapter模式下,使用可选项里唯一一个WIFI选项,Microsoft Virtual Wifi Miniport Adapter也无法上网,故弃之。...2013-09-19
- 首先要声明一点,大部分情况下,修改MySQL密码是需要有mysql里的root权限的...2013-09-11
- MySQL命令行导出数据库: 1,进入MySQL目录下的bin文件夹:cd MySQL中到bin文件夹的目录 如我输入的命令行:cd C:/Program Files/MySQL/MySQL Server 4.1/bin (或者直接将windows的环境变量path中添加该目录) ...2013-09-26
- 一、连接Mysql格式: mysql -h主机地址 -u用户名 -p用户密码1、连接到本机上的MYSQL。首先打开DOS窗口,然后进入目录mysql/bin,再键入命令mysql -u root -p,回车后提示你输密码.注意用户名前可以有空格也可以没有空格,但是密...2015-11-08
- Navicat for MySQL注册码用来激活 Navicat for MySQL 软件,只要拥有 Navicat 注册码就能激活相应的 Navicat 产品。这篇文章主要介绍了Navicat for MySQL 11注册码\激活码汇总,需要的朋友可以参考下...2020-11-23
- 这篇文章主要介绍了mysql IS NULL使用索引案例讲解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下...2021-08-14
- 本文章来给大家详细介绍在php中如何来调用执行mysql存储过程然后返回由存储过程返回的值了,有需要了解的同学可进入参考。 。调用存储过程的方法。 a。如果存储过...2016-11-25
- 这篇文章主要介绍了基于PostgreSQL和mysql数据类型对比兼容,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-12-25
- 一、准备编译环境,安装所需依赖包yum groupinstall 'Development' -y yum install openssl openssl-devel zlib zlib-devel -y yum install readline-devel pcre-devel ncurses-devel bison-devel cmake -y二、编译安...2015-10-21
Mysql中 show table status 获取表信息的方法
这篇文章主要介绍了Mysql中 show table status 获取表信息的方法的相关资料,需要的朋友可以参考下...2016-03-12