MySQL:存储过程

使用存储过程的意义

  1. 简化操作,减少冗余的操作步骤
  2. 减少操作过程中的失误,提高效率

概述

存储过程是一条或者多条SQL语句的集合

存储过程创建方法

CREATE PROCEDURE sp_name ([proc_parameter])
[characteristics…] routine_body

CREATE PROCEDURE: 用来创建存储函数的关键字
sp_name: 存储过程的名称
proc_parameter: 指定存储过程的参数列表,形式如下
[ IN | OUT | INOUT ] param_name type
IN: 输入参数,默认值 OUT: 输出参数 INOUT: 既可以输入也可以输出
param_name: 参数名称
type: 参数类型,可以是MySQL数据库中的任意类型
chracteristics: 制定存储过程的特性
routine_body: SQL代码内容,可以用BEGIN…END来表示SQL代码的开始和结束
在这里插入图片描述

DELIMITER语句

作用:改变结束符
使用方法: DELIMITER //,将MySQL的结束符设置为//
因为MySQL默认的语句结束符号为分号;,为了避免与存储过程中
SQL语句结束符相冲突,需要使用DELIMITER改变存储过程的结束符,并以END //结束存储过程。存储过程定义完毕之后在使用DELIMITER ;恢复默认结束符。DELIMITER也可以指定其他符号作为结束符。
DELIMITER //
CREATE PROCEDURE TEST()
BEGIN
SELECT * FROM TEST;
END //
DELIMITER ;
在这里插入图片描述

调用存储过程

方法:CALL pro_name([proc_parameter]);
例:
DELIMITER //
CREATE PROCEDURE TEST()
BEGIN
SELECT * FROM TEST;
END //
DELIMITER ;
CALL test();
在这里插入图片描述

应用参数

  1. set赋值全局变量
    在这里插入图片描述
  2. SELECT…INTO…方式赋值 先赋值,在执行
    在这里插入图片描述
  3. IN类型参数:输入参数

在这里插入图片描述
3. out参数类型:输出参数,存储结构用输出参数返回值
在这里插入图片描述

流程控制

  1. IF判断语句
    在这里插入图片描述
  2. WHILE循环语句
    在这里插入图片描述
  3. CASE判断语句
    在这里插入图片描述

执行预处理语句

语法格式:
PREPARE statement_name FROM preparable_SQL_statement
EXECUTE statement_name
–statement_name为预处理名称,preparable_SQL_statment为预先准备好的文本SQL语句。
例:用预处理语句执行”查询t1表”的SQL语句
在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值