文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL数据库提升篇-----存储过程和函数

2024-04-02 19:55

关注

day06 MySQL数据库存储过程和函数

一、存储过程和函数的概述:

    数据库的存储过程和存储函数是指在数据库中定义的一些sql语句的集合,直接调用这些存储过程的名字或存储函数的名字就可以直接使用这些sql。可以避免开发人员大量的写一些sql语句操作数据,可以减少客户端和服务器端的数据传输。所以,学好存储过程和存储函数也是很重要的哦!


二、存储过程【procedure】

    1、创建存储过程

        create procedure 自定义一个存储名()
        begin 
            select 语句
        end;
        
        call 存储名();    调用存储过程

   2、删除存储过程

        drop procedure 存储名;

    3、带参数的存储过程

        3.1:in参数,即输入参数

             create procedure 存储名(in 列名 数据类型)
             begin 
                select 语句
             end;
             
             call 存储名(列名的值);

        3.2:out参数,即输出参数

             create procedure 存储名(out 列名 数据类型)
             begin 
                select * into 列名 from 表名;
             end;
             
             call 存储名(@列名);

        3.3:inout参数,即输入输出参数

            create procedure 存储名(inout 列名 数据类型)
             begin 
                 select * into 列名 from 表名;
             end;
             
             set @列名=某个值    //定义一个变量并赋值
             
             call 存储名(@列名);

    4、定义变量

        4.1:定义局部变量

            declare a int   //定义
            set a=10;       //赋值
            select a;       //输出

        4.2:定义全局变量“@作为起始符”

            set @b=20;    //定义会话变量
            select @b;    //输出


三、存储函数【function】

    1、创建存储函数定义的实例。

      create function 函数名(a int , b int) returns int
      begin
          declare c int;
          set c=a+b;
          return c;
      end;
      
      select 函数名(a的数值,b的数值)     //调用存储函数

四、光标的运用

    在MySQL查询数据库肿,存储过程和存储函数中使用光标可以实现逐条的读取结果集中的记录。主要包括以下几个步骤:

    1、声明光标:

        declare  光标名  cursor  select_name
        译;select_name:是一个select语句,返回一行或多行数据。

        实例:

         declare  info_student  cursor for select
         sid,name,age
         from student
         where sid=1;

    2、打开光标

        open  光标名称

    3、使用光标

        fetch  光标名称  into 列名;

    4、关闭光标

        close  光标名称

五、查看存储过程和函数

    1、使用show status 语句查看

        show  { procedure | function } status [like 'pattern']
        译:
            procedure:表示查询存储过程
            function:表示查询存储函数
            like 'pattern':用来匹配存储过程或函数名称。

    2、使用show create语句查看

        show create { procedure | function } sp_name;
        译;
            procedure:表示查询存储过程
            function:表示查询存储函数
            sp_name:表示存储过程或函数名称

    3、修改存储过程和存储函数

             alter { procedure | function } sp_name 
        { contains sql | no sql | reads sql data | modifies sql data }
        | sql security { definer | invoker }
        | comment 'string'
        译:
             procedure | function:表示是存储过程还是存储函数
             sp_name :表示名称
             contains sql:表示子程序包含sql语句,但是不包含读写数据的语句
             no sql:表示子程序包含sql语句
             reads sql data:表示子程序中包含读数据的语句
             modifies sql data :表示子程序中包含写数据的语句
             definer | invoker:表示指明权限执行,前者是定义者自己能够执行,
                                 后者是调用者可以执行
             comment 'string':注释信息

    4、删除存储过程和存储函数

         drop  { procedure | function } sp_name



六、结束语:

    学到这里,存储过程和存储函数就已经学完了哦!好好消化一下吧!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯