iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql存储过程原理与用法详解
  • 673
分享到

mysql存储过程原理与用法详解

mysql存储过程 2022-05-31 21:05:16 673人浏览 独家记忆
摘要

本文实例讲述了Mysql存储过程原理与用法。分享给大家供大家参考,具体如下: 本文内容: 什么是存储过程 存储过程的创建 存储过程的使用 查看存储过程 修改存储过程 删除存储过程 首发日期

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

本文内容:

  • 什么是存储过程
  • 存储过程的创建
  • 存储过程的使用
  • 查看存储过程
  • 修改存储过程
  • 删除存储过程

首发日期:2018-04-17


什么是存储过程:

  • 存储过程存储了一系列sql语句
  • 存储过程的需求场景:下边是一个经典的需求场景,很多mysql的书都有:image
  • 存储过程存储了一系列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 存储过程名 选项;
    • image

删除存储过程:

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

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

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

您可能感兴趣的文档:

--结束END--

本文标题: mysql存储过程原理与用法详解

本文链接: https://www.lsjlt.com/news/9547.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • oracle怎么查询当前用户所有的表
    要查询当前用户拥有的所有表,可以使用以下 sql 命令:select * from user_tables; 如何查询当前用户拥有的所有表 要查询当前用户拥有的所有表,可以使...
    99+
    2024-05-15
    oracle
  • oracle怎么备份表中数据
    oracle 表数据备份的方法包括:导出数据 (exp):将表数据导出到外部文件。导入数据 (imp):将导出文件中的数据导入表中。用户管理的备份 (umr):允许用户控制备份和恢复过程...
    99+
    2024-05-15
    oracle
  • oracle怎么做到数据实时备份
    oracle 实时备份通过持续保持数据库和事务日志的副本来实现数据保护,提供快速恢复。实现机制主要包括归档重做日志和 asm 卷管理系统。它最小化数据丢失、加快恢复时间、消除手动备份任务...
    99+
    2024-05-15
    oracle 数据丢失
  • oracle怎么查询所有的表空间
    要查询 oracle 中的所有表空间,可以使用 sql 语句 "select tablespace_name from dba_tablespaces",其中 dba_tabl...
    99+
    2024-05-15
    oracle
  • oracle怎么创建新用户并赋予权限设置
    答案:要创建 oracle 新用户,请执行以下步骤:以具有 create user 权限的用户身份登录;在 sql*plus 窗口中输入 create user identified ...
    99+
    2024-05-15
    oracle
  • oracle怎么建立新用户
    在 oracle 数据库中创建用户的方法:使用 sql*plus 连接数据库;使用 create user 语法创建新用户;根据用户需要授予权限;注销并重新登录以使更改生效。 如何在 ...
    99+
    2024-05-15
    oracle
  • oracle怎么创建新用户并赋予权限密码
    本教程详细介绍了如何使用 oracle 创建一个新用户并授予其权限:创建新用户并设置密码。授予对特定表的读写权限。授予创建序列的权限。根据需要授予其他权限。 如何使用 Oracle 创...
    99+
    2024-05-15
    oracle
  • oracle怎么查询时间段内的数据记录表
    在 oracle 数据库中查询指定时间段内的数据记录表,可以使用 between 操作符,用于比较日期或时间的范围。语法:select * from table_name wh...
    99+
    2024-05-15
    oracle
  • oracle怎么查看表的分区
    问题:如何查看 oracle 表的分区?步骤:查询数据字典视图 all_tab_partitions,指定表名。结果显示分区名称、上边界值和下边界值。 如何查看 Oracle 表的分区...
    99+
    2024-05-15
    oracle
  • oracle怎么导入dump文件
    要导入 dump 文件,请先停止 oracle 服务,然后使用 impdp 命令。步骤包括:停止 oracle 数据库服务。导航到 oracle 数据泵工具目录。使用 impdp 命令导...
    99+
    2024-05-15
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作