本文实例讲述了Mysql存储过程原理与用法。分享给大家供大家参考,具体如下:

本文内容: 什么是存储过程 存储过程的创建 存储过程的使用 查看存储过程 修改存储过程 删除存储过程

首发日期:2018-04-17

什么是存储过程: 存储过程存储了一系列sql语句 存储过程的需求场景:下边是一个经典的需求场景,很多Mysql的书都有:

存储过程存储了一系列sql语句,使得简化了操作,不要求重复执行一系列操作。只需要在需要的时候调用一下存储过程就行了。 一般来说,可以认为存储过程的功能与函数的功能类似(应该都学过函数吧),但只是要注意存储过程没有返回值,所以可以依据函数可用场景来理解存储过程。

补充: 存储过程与触发器的区别:触发器触发事件就执行一系列语句;而存储过程是调用,而且存储过程还要根据情况考虑执行“另外一系列语句”。 存储过程与函数的区别:函数有返回值,而存储过程没有【所以不能使用在select语句中】

存储过程的创建: create procedure 存储过程名 ([参数列表]) begin sql 语句 end; 参数列表的格式:[类型限定 变量名 数据类型] 参数列表有自己的类型限定,这个类型限定与数据类型不同,它是限定参数的作用范围 in:限定这个参数是传值给存储过程,既然是传值,所以可以是变量或常量数据【in修饰的参数一般是传入存储过程中作为某些条件的,不会被存储过程修改】 out:限定这个参数是存储过程传出的一个值,因为有值的返回,所以这个参数必须是一个变量【存储过程中会给out修饰的变量赋值,使得过程外部可以获取这个更改的值】 inout:inout是上面两者的叠加,既可以被存储过程内部使用,又可以修改后被外部使用,因为有值的返回,所以这个参数必须是一个变量 理论上,对于希望简洁代码的地方都可以使用存储过程来处理,比如希望快速使用多条select,又比如希望从数据中取出多个值赋值给变量;所以下面只给出用法,应用场景就不讲述了。 1:不传入参数,只执行某些特定代码 2.传入参数,并利用参数作为条件执行代码 3.传入参数,并利用参数作为条件执行代码,同时利用变量获取结果。 【下面的call是调用过程】 -- 最简单的例子

create procedure myselect()

begin

select @@version;

end;

create procedure getInfo(in mname varchar(15))

begin

select mname;

end;

call myselect();

call getInfo("lilie");

-- 能通过传参来获取指定内容的

create procedure getInfo2(in mname varchar(15))

begin

select * from student where name =mname;

end;

call getInfo2("lilei");

-- 将结果赋值给一个变量传到外部

create procedure getInfo3(in mname varchar(15),out oname varchar(15))

begin

select name from student where name =mname into oname;

end;

call getInfo3("lilei",@mname);

select @mname;

补充: 与触发器类似,如果在命令行模式下进行存储过程创建,需要修改命令结束符。 还可以有一些特别的选项,特别的选项写在([参数列表]) 之后,begin之前 comment:是这个存储过程的一个描述 create procedure myselect2()

comment "我的一系列sql语句"

begin

select * from student;

select * from class;

end;

show create procedure myselect2; 还有一些比如sql security等选项,有兴趣可以自行百度。这里不讲解,仅一提有此知识点。

存储过程的使用: 调用存储过程:call 存储过程名(); 带参数的调用存储过程:call 存储过程名(参数); 对于in类型的,参数可以是数值,可以是变量 对于out\inout类型的,参数必须是变量 所有MySQL变量都必须以 @ 开始 示例:call myselect("lilei",@变量名);示例:call myselect(@变量名,@变量名)

下面调用的存储过程就是上面创建存储过程中定义的存储过程: call myselect();

call getInfo("lilie");

set @mname="lilei";

call getInfo(@mname);

call getInfo3("lilei",@mname);

变量的使用: out和inout能修改会被存储过程修改的变量,但这个修改会在存储过程调用结束后才会成功修改【就好像如果在过程内部现有一条命令是修改的,可以在此命令后面查看一下变量,发现全局变量并没有改变,改变的只是局部变量】。 所有MySQL变量都必须以 @ 开始 存储过程中,使用局部变量可以使用select 变量名;使用全局变量可以使用select @变量名; 关于具体变量的定义与使用将在我的另外一篇博文中讲解。超链接:mysql之变量

查看存储过程: 查看存储过程的创建语句:show create procedure 存储过程名; 查看存储过程状态:show procedure status;【显示的内容包括创建时间、注释、定义的用户、安全类型等等】

修改存储过程: 修改存储过程只能修改那些选项(这里不讲解那些具体选项,想了解的可以自行百度),并不能修改传入传出参数或者sql语句。 alter procedure 存储过程名 选项;

删除存储过程: 语法:drop procedure 存储过程名; 示例: drop procedure getInfo;

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL存储过程技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》及《MySQL数据库锁相关技巧汇总》

希望本文所述对大家MySQL数据库计有所帮助。

mysql的存储过程原理_mysql存储过程原理与用法详解相关推荐

  1. revoke mysql_浅谈MySQL中授权(grant)和撤销授权(revoke)用法详解

    MySQL 赋予用户权限命令的简单格式可概括为: grant 权限 on 数据库对象 to 用户 一.grant 普通数据用户,查询.插入.更新.删除 数据库中所有表数据的权利 grant selec ...

  2. mysql revoke 授权_浅谈MySQL中授权(grant)和撤销授权(revoke)用法详解

    MySQL 赋予用户权限命令的简单格式可概括为: grant 权限 on 数据库对象 to 用户 一.grant 普通数据用户,查询.插入.更新.删除 数据库中所有表数据的权利 grant selec ...

  3. mysql 从第几位开始截取_mysql的截取函数用法详解

    原标题:mysql的截取函数用法详解 substring()函数 测试数据准备: 用法: 以下语法是mysql自动提示的 1:substirng(str,pos):从指定位置开始截取一直到数据完成 s ...

  4. mysql数据库杀掉堵塞_Mysql解决USE DB堵塞详解

    遇到故障,我们往往想的是如何解决这个故障,而不是从故障的根本去思考出现这个故障的原因?这样的结果,只能使我们得到了鱼,失去了渔.今天,我们就来分享一个由USE DB堵塞故障引发的思考案例. 故障描述 ...

  5. mysql 配置自动截断_MySql超长自动截断实例详解

    MySql超长自动截断实例详解 小伙伴问到一个问题,为啥在项目中调用插入或者更新语句时超长的字无法自动截断,而在navicat中直接执行是可以自动截断的? 如下 CREATE TABLE `p_app ...

  6. mysql 超长 java 问题_MySql超长自动截断实例详解

    MySql超长自动截断实例详解 小伙伴问到一个问题,为啥在项目中调用插入或者更新语句时超长的字无法自动截断,而在navicat中直接执行是可以自动截断的? 如下 CREATE TABLE `p_app ...

  7. mysql中find_in_set()函数的使用及in()用法详解

    From: http://www.manongjc.com/article/2710.html MySQL手册中find_in_set函数的语法解释: FIND_IN_SET(str,strlist) ...

  8. mysql in边界_mysql中 where in 用法详解

    这里分两种情况来介绍 WHERE column IN (value1,value2,...) WHERE column NOT IN (value1,value2,...) 1.in 后面是记录集,如 ...

  9. mysql数据表操作_MySQL数据表基本操作实例详解

    本文实例讲述了MySQL数据表基本操作.分享给大家供大家参考,具体如下: 数据表的基本操作 1.主键约束要求主键列的数据唯一,并且不允许为空.主键能够唯一地识别表中的一条记录,可以结合外键来定义不同数 ...

  10. mysql 秒杀 隔离级别_MySQL 四种隔离级别详解,看完吊打面试官

    什么是事务 事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消.也就是事务具有原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做. 事务的结束有 ...

最新文章

  1. 软件缺陷管理工具大全
  2. 从0开始学习GitHub系列之「认识并加入GitHub」
  3. SQL高效率语句(一)
  4. 杠件受力分析 第一章 杠件受力分析
  5. boot spring test 文档_Spring、Spring Boot 和 TestNG 测试指南 ( 3 )
  6. HDU 4873 ZCC Loves Intersection(可能性)
  7. java更新word目录_java aspose.words 生成word目录和更新目录
  8. 魅族计算机软件不见了,任务栏不见了
  9. 微型计算机第十一章答案,计算机习题答案总.docx
  10. 2012服务器系统显示这台电脑,两台windows server 2012 R2 服务器 故障:计算机已经从检测错误后重新启动。请问如何解决?...
  11. JS时间戳转YY-MM-DD
  12. 代价函数,损失函数,目标函数区别
  13. 【Koltin Flow(二)】Flow操作符之末端操作符
  14. Matlab 添加工具包的操作
  15. 空气质量指数计算1.0
  16. PostgreSQL9.4基于pglogical发布订阅功能实现及操作
  17. Linux开机 进入图形界面或命令行界面
  18. TJA1050T CAN总线通信硬件原理
  19. 物联网操作系统HelloX已成功移植到MinnowBoard MAX开发板上
  20. 12年,等来一只绿茶婊

热门文章

  1. const * 和 * const 的区别
  2. 2020-11-6(简述html)
  3. 【easysnmp】python snmp IF-MIB::ifPhysAddress messy code,解析mac地址乱码
  4. 【prometheus API】删除指定指标数据
  5. 5、修改视图(ALTER VIEW)
  6. 1021 Deepest Root (25 分) 【难度: 中 / 知识点: 树的直径 连通块】
  7. 【PAT乙级】1078 字符串压缩与解压 (20 分)
  8. MySQL创建视图的语法格式
  9. Java之Character类
  10. 一天1个机器学习知识点(四)