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

作者:随风行云 时间:2024-01-26 02:50:54 

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

本文内容:

  • 什么是存储过程

  • 存储过程的创建

  • 存储过程的使用

  • 查看存储过程

  • 修改存储过程

  • 删除存储过程

首发日期:2018-04-17


什么是存储过程:

  • 存储过程存储了一系列sql语句

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


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


    删除存储过程:

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

    • 示例:

    • drop procedure getInfo;

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

    来源:https://www.cnblogs.com/progor/p/8866574.html

    标签:mysql,存储过程
    0
    投稿

    猜你喜欢

  • Swin Transformer图像处理深度学习模型

    2022-01-16 22:32:08
  • Python实现身份证前六位地区码对照表文件

    2022-12-25 10:55:16
  • ORACLE11g随RHEL5系统自动启动与关闭的设置方法

    2009-08-31 12:43:00
  • 浅谈spring boot 集成 log4j 解决与logback冲突的问题

    2023-06-22 13:12:05
  • Python pymsql模块的使用

    2023-01-08 15:23:00
  • 不固定参数的存储过程实现代码

    2024-01-22 16:36:39
  • Django 实现图片上传和显示过程详解

    2022-06-13 22:22:27
  • Tensorflow实现在训练好的模型上进行测试

    2022-10-04 07:17:00
  • SQL SERVER 日志已满的处理方法

    2010-07-31 13:32:00
  • 自制Python淘宝秒杀抢购脚本双十一百分百中

    2022-01-25 07:02:18
  • 如何避免asp的SQL的执行效率低

    2009-01-08 18:18:00
  • python如何实现单链表的反转

    2023-05-11 12:44:10
  • 简单谈谈Python流程控制语句

    2023-03-12 12:34:25
  • 详解python requests中的post请求的参数问题

    2023-09-20 07:50:40
  • php函数之子字符串替换 str_replace

    2023-11-23 17:32:29
  • python编写WAF与Sqlmap结合实现指纹探测

    2022-05-23 08:10:17
  • tensorflow识别自己手写数字

    2022-10-12 20:25:04
  • XML和XSLT结合使网站设计浑然一体

    2008-09-05 17:13:00
  • 在Internet Explorer中正确使用MSXML

    2009-02-22 18:41:00
  • php插件功能实现方法介绍

    2023-05-30 12:28:52
  • asp之家 网络编程 m.aspxhome.com