美文网首页
mysql存储过程

mysql存储过程

作者: wqjcarnation | 来源:发表于2021-07-29 16:03 被阅读0次

    MySQL 5.0 版本开始支持存储过程。

    存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据库对象。

    存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行。

    存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。

    优点
    存储过程可封装,并隐藏复杂的商业逻辑。
    存储过程可以回传值,并可以接受参数。
    存储过程无法使用 SELECT 指令来运行,因为它是子程序,与查看表,数据表或用户定义函数不同。
    存储过程可以用在数据检验,强制实行商业逻辑等。
    缺点
    存储过程,往往定制化于特定的数据库上,因为支持的编程语言不同。当切换到其他厂商的数据库系统时,需要重写原有的存储过程。
    存储过程的性能调校与撰写,受限于各种数据库系统。

    一、存储过程的创建和调用
    存储过程就是具有名字的一段代码,用来完成一个特定的功能。
    创建的存储过程保存在数据库的数据字典中。
    创建存储过程

    CREATE
    [DEFINER = { user | CURRENT_USER }]
     PROCEDURE sp_name ([proc_parameter[,...]])
    [characteristic ...] routine_body

    proc_parameter:
    [ IN | OUT | INOUT ] param_name type

    characteristic:
    COMMENT 'string'
    | LANGUAGE SQL
    | [NOT] DETERMINISTIC
    | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
    | SQL SECURITY { DEFINER | INVOKER }

    routine_body:
      Valid SQL routine statement

    [begin_label:] BEGIN
      [statement_list]
        ……
    END [end_label]

    简单例子

    mysql> delimiter #将语句的结束符号从分号;临时改为两个(可以是自定义)
    mysql> CREATE PROCEDURE delete_matches(IN p_playerno INTEGER)
    -> BEGIN
    ->   DELETE FROM MATCHES
    -> WHERE playerno = p_playerno;
    -> END$$

    调用存储过程:
    call delete_matches(12)

    delimiter create procedure myproc(in parameter1 integer) begin select parameter1; set parameter1=2; select parameter1; end
    delimiter ;

    set @parameter1=1;
    call myproc(@parameter1);

    delimiter create procedure myproc2(out p_out integer) begin select p_out; set p_out=2; select p_out; end
    delimiter ;

    set @p_out=1;
    call myproc2(@p_out);

    级联删除的例子

    delimiter $$
    create PROCEDURE delcontype2(in typeid integer)
    begin
    -- 先删除分类下constantitem表的consanttypeid=4的子项目(男女)
    delete from constantitem where constanttypeid=@typeid;

    -- 再删除对应的分类constanttype里id=4的
    delete from constanttype where id=@typeid;
    end $$
    delimiter ;

    set @typeid=4;
    call delcontype2(@typeid);

    相关文章

      网友评论

          本文标题:mysql存储过程

          本文链接:https://www.haomeiwen.com/subject/zznxvltx.html