代码中被[]包含的表示可选,|符号分开的表示可选其一。

需求背景介绍

线上程序有时候出现问题导致数据错误的时候,如果比较紧急,我们可以写一个存储来快速修复这块的数据,然后再去修复程序,这种方式我们用到过不少。

存储过程相对于java程序对于java开发来说,可能并不是太好维护以及阅读,所以不建议在程序中去调用存储过程做一些业务操作。

关于自定义函数这块,若mysql内部自带的一些函数无法满足我们的需求的时候,我们可以自己开发一些自定义函数来使用。

所以建议大家掌握mysql中存储过程和自定义函数这块的内容。

本文内容

  • 详解存储过程的使用

  • 详解自定义函数的使用

一、存储过程  

  概念

    一组预编译好的sql语句集合,理解成批处理语句。

  好处:

  • 提高代码的重用性

  • 简化操作

  • 减少编译次数并且减少和数据库服务器连接的次数,提高了效率。

  创建存储过程

    create procedure 存储过程名([参数模式] 参数名 参数类型)
    begin
        存储过程体
    end  

  参数模式有3种:

    in:该参数可以作为输入,也就是该参数需要调用方传入值。

    out:该参数可以作为输出,也就是说该参数可以作为返回值。

    inout:该参数既可以作为输入也可以作为输出,也就是说该参数需要在调用的时候传入值,又可以作为返回值。

  参数模式默认为IN。

    一个存储过程可以有多个输入、多个输出、多个输入输出参数。  

  调用存储过程

    call 存储过程名称(参数列表);

  删除存储过程

    drop procedure [if exists] 存储过程名称;  

    存储过程只能一个个删除,不能批量删除。

    if exists:表示存储过程存在的情况下删除。  

  修改存储过程

    存储过程不能修改,若涉及到修改的,可以先删除,然后重建。  

  查看存储过程

    show create procedure 存储过程名称;  ----可以查看存储过程详细创建语句。  

  示例  

    示例1:空参列表

    创建存储过程

    /*设置结束符为$*/
    DELIMITER $
    /*如果存储过程存在则删除*/
    DROP PROCEDURE IF EXISTS proc1;
    /*创建存储过程proc1*/
    CREATE PROCEDURE proc1()
      BEGIN
        INSERT INTO t_user VALUES (1,30,'路人甲Java');
        INSERT INTO t_user VALUES (2,50,'刘德华');
      END $     /*将结束符置为;*/
    DELIMITER ;

    delimiter用来设置结束符,当mysql执行脚本的时候,遇到结束符的时候,会把结束符前面的所有语句作为一个整体运行,存储过程中的脚本有多个sql,但是需要作为一个整体运行,所以此处用到了delimiter。

    mysql默认结束符是分号。

    上面存储过程中向t_user表中插入了2条数据。

    调用存储过程:

      CALL proc1();    

    示例2:带in参数的存储过程      

    创建存储过程:

    /*设置结束符为$*/
    DELIMITER $
    /*如果存储过程存在则删除*/
    DROP PROCEDURE IF EXISTS proc2;
    /*创建存储过程proc2*/
    CREATE PROCEDURE proc2(id int,age int,in name varchar(16))
      BEGIN
        INSERT INTO t_user VALUES (id,age,name);
      END $     /*将结束符置为;*/
    DELIMITER ;

    调用存储过程:

    /*创建了3个自定义变量*/
    SELECT @id:=3,@age:=56,@name:='张学友';
    /*调用存储过程*/
    CALL proc2(@id,@age,@name);
    示例3:带out参数的存储过程

    创建存储过程:

    delete a from t_user a where a.id = 4;
    /*如果存储过程存在则删除*/
    DROP PROCEDURE IF EXISTS proc3;
    /*设置结束符为$*/
    DELIMITER $
    /*创建存储过程proc3*/
    CREATE PROCEDURE proc3(id int,age int,in name varchar(16),out user_count int,out max_id INT)
      BEGIN
        INSERT INTO t_user VALUES (id,age,name);
        /*查询出t_user表的记录,放入user_count中,max_id用来存储t_user中最小的id*/
        SELECT COUNT(*),max(id) into user_count,max_id from t_user;
      END $     /*将结束符置为;*/
    DELIMITER ;

proc3中前2个参数,没有指定参数模式,默认为in。

    调用存储过程:

    /*创建了3个自定义变量*/
    SELECT @id:=4,@age:=55,@name:='郭富城';
    /*调用存储过程*/
    CALL proc3(@id,@age,@name,@user_count,@max_id);
    示例4:带inout参数的存储过程

    创建存储过程:

    /*如果存储过程存在则删除*/
    DROP PROCEDURE IF EXISTS proc4;
    /*设置结束符为$*/
    DELIMITER $
    /*创建存储过程proc4*/
    CREATE PROCEDURE proc4(INOUT a int,INOUT b int)
      BEGIN
        SET a = a*2;
        select b*2 into b;
      END $     /*将结束符置为;*/
    DELIMITER ;

    调用存储过程:

    /*创建了2个自定义变量*/
    set @a=10,@b:=20;
    /*调用存储过程*/
    CALL proc4(@a,@b);
    示例5:查看存储过程

      show create procedure proc4;

二、函数

  概念

  一组预编译好的sql语句集合,理解成批处理语句。类似于java中的方法,但是必须有返回值。

  创建函数

    create function 函数名(参数名称 参数类型)
    returns 返回值类型
    begin
        函数体
    end    

    参数是可选的。

    返回值是必须的。  

  调用函数

    select 函数名(实参列表);  

  删除函数

    drop function [if exists] 函数名;  

  查看函数详细

    show create function 函数名;  

  示例

    示例1:无参函数

    创建函数:

    /*删除fun1*/
    DROP FUNCTION IF EXISTS fun1;
    /*设置结束符为$*/
    DELIMITER $
    /*创建函数*/
    CREATE FUNCTION fun1()
      returns INT
      BEGIN
        DECLARE max_id int DEFAULT 0;
        SELECT max(id) INTO max_id FROM t_user;
        return max_id;
      END $
    /*设置结束符为;*/
    DELIMITER ;  
    
    调用:SELECT fun1();
    示例2:有参函数    

    创建函数:

    /*删除函数*/
    DROP FUNCTION IF EXISTS get_user_id;
    /*设置结束符为$*/
    DELIMITER $
    /*创建函数*/
    CREATE FUNCTION get_user_id(v_name VARCHAR(16))
      returns INT
      BEGIN
        DECLARE r_id int;
        SELECT id INTO r_id FROM t_user WHERE name = v_name;
        return r_id;
      END $
    /*设置结束符为;*/
    DELIMITER ;     调用:SELECT get_user_id(name) from t_user;

存储过程和函数的区别

存储过程的关键字为procedure,返回值可以有多个,调用时用call一般用于执行比较复杂的的过程体、更新、创建等语句

函数的关键字为function返回值必须有一个,调用用select,一般用于查询单个值并返回。

  存储过程 函数
返回值 可以有0个或者多个 必须有一个
关键字 procedure function
调用方式 call select

 
 
 
 
 
 

十七、存储过程&自定义函数详解的更多相关文章

  1. MSSQL 自定义函数详解

    自定义函数分为:标量值函数或表值函数 如果 RETURNS 子句指定一种标量数据类型,则函数为标量值函数.可以使用多条 Transact-SQL 语句定义标量值函数. 如果 RETURNS 子句指定 ...

  2. MySql存储过程与函数详解

    存储过程和函数是在数据库中定义一些SQL语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的SQL语句.存储过程和函数可以避免开发人员重复的编写相同的SQL语句.而且,存储过程和函数是在MyS ...

  3. 【转】angularjs指令中的compile与link函数详解

    这篇文章主要介绍了angularjs指令中的compile与link函数详解,本文同时诉大家complie,pre-link,post-link的用法与区别等内容,需要的朋友可以参考下   通常大家在 ...

  4. angularjs指令中的compile与link函数详解

    这篇文章主要介绍了angularjs指令中的compile与link函数详解,本文同时诉大家complie,pre-link,post-link的用法与区别等内容,需要的朋友可以参考下   通常大家在 ...

  5. jQuery.ready() 函数详解

    jQuery.ready() 函数详解 ready()函数用于在当前文档结构载入完毕后立即执行指定的函数. 该函数的作用相当于window.onload事件. 你可以多次调用该函数,从而绑定多个函数, ...

  6. loadrunner 脚本优化-关联函数web_reg_save_param()函数详解

    脚本优化-关联函数web_reg_save_param()函数详解   by:授客 QQ:1033553122 Insert->New Step,打开Add Step对话框 选择函数web_re ...

  7. AdapterView的使用与getView函数详解

    作者:徐冉.文章首发在他的个人博客. ) AdapterView&Adapter家族 adapterview就是和数据有关的控件,如listview,gridview,spinnerview等 ...

  8. Jupyter自定义设置详解

    今天专门花时间总结梳理一下jupyter的一些高级设置,jupyter我已经介绍过一次基本内容了,Setup and Linux | James Chen's Blogs,尤其是如何在服务器运行jup ...

  9. malloc 与 free函数详解<转载>

    malloc和free函数详解   本文介绍malloc和free函数的内容. 在C中,对内存的管理是相当重要.下面开始介绍这两个函数: 一.malloc()和free()的基本概念以及基本用法: 1 ...

随机推荐

  1. java String 转Json报错 java.lang.NoClassDefFoundError: org/apache/commons/lang/exception/NestableRuntim

    这个问题就是缺少jar包依赖!!! java.lang.NoClassDefFoundError: org/apache/commons/beanutils/DynaBean 缺少commons-be ...

  2. 暚光科技定位系统数据解析-java

    暚光科技定位系统数据解析-java package com.ygkj.test; import java.io.DataInputStream; import java.io.IOException; ...

  3. SDN实验---Ryu的应用开发(一)Hub实现

    补充: (一)Ubuntu下安装Notepadqq 背景:为什么安装Notepadqq Notepad++ 不仅有语法高亮度显示,也有语法折叠功能,并且支持宏以及扩充基本功能的外挂模组.但是可惜的是N ...

  4. python:pytest优秀博客

    上海悠悠:https://www.cnblogs.com/yoyoketang/tag/pytest/

  5. 码云初次导入项目(Idea)

    一.新建项目  使用ssh时记得配置码云的个人中的秘钥 [问题原因] 远程仓库和本地仓库的内容不一致 [解决方法] 在git项目对应的目录位置打开Git Bash   然后在命令窗输入下面命令: gi ...

  6. win10查看激活到期时间

    我们知道Windows系统需要激活后才可以使用全部功能,那么你的Windows10激活了吗?如何查看激活时间呢?是不是永久激活的?带着这些问题,下面我们就一个一个逐一查看一下吧. 工具/原料   Wi ...

  7. 【视频开发】CximageMat 、CximagelplImage 以及 lplImageMat的转换、像素位深度

    1.传统的lplImage * -------> Mat格式 IplImage* img = cvLoadImage("greatwave.png", 1); Mat mtx ...

  8. UDP中一个包的大小最大能多大?TCP呢?

    (以上为以太网的帧格式) Preamble:前导同步码7个字节+帧开始定界符1个字节=8个字节 Destination MAC adress:目的MAC地址 Source MAC adress:源MA ...

  9. Java开发笔记(一百三十八)JavaFX的箱子

    前面介绍了JavaFX标签控件的用法,其中提到Label文本支持中文字体,那么它到底支持哪些中文字体呢?自然要看当前的操作系统都安装了哪些字体才行,对于中文的Windows系统,默认安装了黑体“Sim ...

  10. C++—多态与继承

    一.基本概念 1.类的继承,是新的类从已有类那里得到已有的特性.或从已有类产生新类的过程就是类的派生.原有的类称为基类或父类,产生的新类称为派生类或子类. 2.派生类的声明: class 派生类名:继 ...