一、概述

存储过程&函数,类似编程语言的方法

什么是方法?

完成特定功能的一组语句

方法的特点

1、可重用性

2、简化操作

二、存储过程【 Stored Procedures】:

一组预先编译好的SQL语句的集合,可理解批处理语句

提供给Java操作复杂的SQL逻辑将会变得困难

交给存储过程将减少Java的逻辑复杂程度,减少编译次数和数据库服务的连接次数

提高SQL效率

适用场景:

大型系统项目

三、语法和使用

1、总体语法:

CREATE PROCEDURE 存储过程标识符(参数列表)

BEGIN (开始过程)

# 存储过程【一组符合语法的SQL语句】

END (结束过程)

2、参数的写法:

参数模式 参数名称 参数类型

样例:

IN aaa VARCHAR(24)

3、参数模式的种类:

IN
# 仅输入,需要调用方法传入值 OUT
# 仅输出,可以作为存储过程的返回值,等同Java的返回类型声明 INOUT
# 兼输入输出

4、语法事项:

1、如果存储过程只有一句SQL语句需要执行,可以不写BEGIN & END

2、每条SQL语句的结尾必须协商分号

3、存储过程的结尾关键字可以使用DELIMTER关键字重新设置

5、DELIMITER使用

DELIMITER 结束标记

6、存储过程的调用语法

CALL 存储过程名称(实际参数);

四、三种参数模式的案例:

无参存储过程

创建一个存储过程

DELIMITER $

CREATE PROCEDURE batchInsert()
BEGIN
INSERT INTO
admin(`username`,`password`)
VALUES
('john','3333'),
('rose','4444'),
('jack','5555'),
('tomy','6666'),
('jerry','7777');
END $

创建完成之后会保留在数据库中

调用存储过程:

在案例中需要使用$在存储过程的结尾写上

但是发现报错:

错误代码: 1064
You have an error in your SQL syntax;
check the manual that corresponds to your MySQL server version for the right syntax to use near '$' at line 1

SQL语法检查发现不需要添加$,执行成功

CALL batchInsert()

带IN模式参数的存储过程

报错发现每次必须要声明 结尾标识

这个结尾标识必须紧跟END

DELIMITER $
CREATE PROCEDURE queryBoyInfoByGirlName(IN beautyName VARCHAR(20))
BEGIN
SELECT
bo.*
FROM
boys bo RIGHT JOIN beauty b ON bo.id = b.boyfriend_id
WHERE
b.name = beautyName;
END$

存储过程调用:

CALL `queryBoyInfoByGirlName`('热巴')

多IN模式参数存储过程:

DELIMITER $
CREATE PROCEDURE login
(
IN `username` VARCHAR(20),
IN `password` VARCHAR(20)
)
BEGIN
DECLARE result VARCHAR(20) DEFAULT '';
# ------------------------------------------
SELECT
COUNT(*)
INTO
result
FROM
admin
WHERE
admin.`username` = `username`
AND
admin.`password` = `password`;
# ------------------------------------------
SELECT result;
END $

存储过程调用:

CALL login('john', '8888');

如果还需要显示成功或者失败字符

DELIMITER $
CREATE PROCEDURE login2
(
IN `username` VARCHAR(20),
IN `password` VARCHAR(20)
)
BEGIN
DECLARE result VARCHAR(20) DEFAULT 0;
# ------------------------------------------
SELECT
COUNT(*)
INTO
result
FROM
admin
WHERE
admin.`username` = `username`
AND
admin.`password` = `password`;
# ------------------------------------------
SELECT IF(result > 0, '登录成功', '登录失败') AS '提示信息';
END $

带Out模式参数的存储过程

DELIMITER $
CREATE PROCEDURE queryGirlNameByBoy
(
IN beautyName VARCHAR(20),
OUT boyName VARCHAR(20)
)
BEGIN
SELECT
boys.`boyName`
INTO
boyName
FROM
boys INNER JOIN beauty ON boys.id = beauty.`boyfriend_id`
WHERE
beauty.`name` = beautyName;
END $

调用时注入一个变量,由变量查询返回

CALL queryGirlNameByBoy('小昭', @bName);
SELECT @bName AS '名称'

除了名字以外,再追加一个CP字段值,重写存储过程

DELIMITER $
CREATE PROCEDURE queryBoyNameAndCpValueByGirlName
(
IN beautyName VARCHAR(20),
OUT boyName VARCHAR(20),
OUT coupleValue INT
)
BEGIN
SELECT
boys.`boyName`, boys.`userCP`
INTO
boyName, coupleValue
FROM
boys INNER JOIN beauty ON boys.id = beauty.`boyfriend_id`
WHERE
beauty.`name` = beautyName;
END $

调用:

CALL queryBoyNameAndCpValueByGirlName
(
'小昭',
@bName,
@userCP
);
SELECT @bName 'NAME', @userCP 'CoupleValue';

带INOUT模式参数的存储过程:

DELIMITER $
CREATE PROCEDURE returnDouble
(
INOUT a INT,
INOUT b INT
)
BEGIN
SET a = a * 2;
SET b = b * 2;
END$

调用:

SET @varA = 125;
SET @varB = 334; CALL returnDouble(@varA, @varB);
SELECT @varA, @varB;

五、存储过程的删除和查看

在之前的案例中我们已经创建了许多存储过程

删除语法:

DROP PROCEDURE 存储过程名称

删除语句一次只能删除一个,不可以实现多个删除

查看语法:

SHOW CREATE PROCEDURE 存储过程名称

六、为什么没有存储过程修改?

存储过程是由修改的SQL的,但是能够修改的只有特定的元数据

不能对存储过程的逻辑进行修改,改了没改都一样,没有太大的意义

详细资料参见:

https://www.cnblogs.com/geaozhang/p/6817698.html

如果要实现我们的真正意义上的修改,就需要先删除存储过程,再重新创建

【DataBase】MySQL 26 存储过程的更多相关文章

  1. Database(Mysql)发版控制二

    author:skate time:2014/08/18 Database(Mysql)发版控制 The Liquibase Tool related Database 一.Installation ...

  2. mysql 的存储过程_多字段

    mysql 的存储过程 一.准备工作 新建一个表 /*Navicat MySQL Data Transfer Source Server : localhost_3306Source Server V ...

  3. MySQL数据库----存储过程

    存储过程 存储过程包含了一系列可执行的sql语句,存储过程存放于MySQL中,通过调用它的名字可以执行其内部的一堆sql -- 存储过程的优点: -- 1.程序与数据实现解耦 -- 2.减少网络传输的 ...

  4. SqlServer和MySQL中存储过程out返回值处理C#代码

    1.SqlServer中out处理 C#代码 #region"SqlServer中存储过程处理out返回值" //public void getdata() //{ // stri ...

  5. MySQL 查询 存储过程 视图 触发器 函数 索引 建表语句 数据库版本 当前登录用户 当前数据库名称

    MySQL 查询 存储过程 视图 触发器 函数 索引 建表语句 数据库版本 当前登录用户 当前数据库名称   INFORMATION_SCHEMA.TABLES INFORMATION_SCHEMA. ...

  6. 在linux下的mysql导入存储过程出现语法错误,需要在文件里加DELIMITER //

    http://my.oschina.net/zerotime/blog/113126 Mysql命令行创建存储过程时,首先要输入分隔符 DELIMITER // CREATE PROCEDURE pr ...

  7. MYSQL中存储过程的创建,调用及语法

    MySQL 存储过程是从 MySQL 5.0 开始增加的新功能.存储过程的优点有一箩筐.不过最主要的还是执行效率和SQL 代码封装.特别是 SQL 代码封装功能,如果没有存储过程,在外部程序访问数据库 ...

  8. 一看便知linux下mysql报错ERROR 1044: Access denied for user: '@localhost' to database 'mysql'

    错误信息:ERROR 1044: Access denied for user: '@localhost' to database 'mysql' linux下解决方案: mysql> use ...

  9. MYSQL分页存储过程及事务处理

    最近给客户做的一小系统是SQLSERVER的数据库,因为特殊原因要切换到MYSQL上去,切换数据库确实让人头疼的,SQLSERVER和MYSQL的存储过程还是有很大差别的,下面是我做切换时转换的MYS ...

  10. mysql之存储过程

    一.存储过程     迄今为止,使用的大多数 SQL语句都是针对一个或多个表的单条语句.并非所有操作都这么简单,经常会有一个完整的操作需要多条语句才能完成.例如,考虑以下的情形.         1. ...

随机推荐

  1. JVM垃圾回收器(详解)

    引言 垃圾回收(GC,Garbage Collection) 在笔者上一篇文章中(JVM内存模型),介绍了JVM内存模型以及JVM运行时的数据区,堆是JVM内存区域里面最大的一块区域,用于存放实例数据 ...

  2. @Transactional事务注解及请求接口的定义先后执行顺序设计

    @Transactional事务注解及请求接口的定义先后执行顺序设计1.事务内查询,可能存在事务没有提交,导致查询数据查不出来. 2.或者可能跟请求参数作为查询条件,在某个条件下,请求参数发生变化,也 ...

  3. Linux curl支持http/https方法,Curl请求示例语法

    Curl请求示例curl -X GET "http://<host:port>/api/1/test/get?test=<value>&app_id=< ...

  4. Redis八股文(大厂面试真题)

    号:tutou123com​我是小宋编码,Java程序员 ,只熬夜但不秃头. 关注我,带你轻松过面试.提升简历亮点如果你觉得对你有帮助,欢迎关注[1] 内容目录 1.说说redis,了解redis源码 ...

  5. Ubuntu 下 python 安装pip

    背景 python的强大在于它的第三方库. 安装 python2 sudo apt-get install python-pip python3 curl https://bootstrap.pypa ...

  6. 数据特征采样在 MySQL 同步一致性校验中的实践

    作者:vivo 互联网存储研发团队 - Shang Yongxing 本文介绍了当前DTS应用中,MySQL数据同步使用到的数据一致性校验工具,并对它的实现思路进行分享. 一.背景 在 MySQL 的 ...

  7. VPS测试脚本,网络线路,路由测试,流媒体服务器测试脚本

    ​ 收集了一些服务器测试脚本,测试性能,网络以及解锁Netflix等服务.记录收集一下,特此记录. yabs测试脚本wget -qO- yabs.sh | bash 老外比较爱用的服务器性能测试脚本. ...

  8. 网易传媒基于 Arctic 的低成本准实时计算实践

    网易传媒大数据实际业务中,存在着大量的准实时计算需求场景,业务方对于数据的实效性要求一般是分钟级:这种场景下,用传统的离线数仓方案不能满足用户在实效性方面的要求,而使用全链路的实时计算方案又会带来较高 ...

  9. mysql Using join buffer (Block Nested Loop) join连接查询优化

    最近在优化链表查询的时候发现就算链接的表里面不到1w的数据链接查询也需要10多秒,这个速度简直不能忍受 通过EXPLAIN发现,extra中有数据是Using join buffer (Block N ...

  10. Bootstrip HTML 查询搜索常用格式模版

    Bootstrip HTML 查询搜索常用格式模版 <form class="form-inline my-3 d-flex align-items-center justify-co ...