MySQL的存储过程是什么?怎么用?

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: MySQL存储过程学习

使用存储过程

存储过程

存储过程简单来说,就是为了以后的使用而保存的一条或多条MySQL语句的集合。可将其视为批文件。但他的作用不仅限于批处理。

为什么要处理存储过程

  • 通过把处理封装在容易使用的单元中,简化复杂的操作。
  • 使用统一存储过程,可防止错误,因为执行的步骤越多,出错的可能性就越大。
  • 简化对变动的管理。如果变动了,我们只需修改存储过程就好。
  • 提高性能,使用存储过程比单独的SQL语句要快
  • 存在一些只能在单个请求中的MySQL元素和特性,存储过程可以使用他们来编写功能更强更灵活的代码。

总而言之就是:简单,安全,高性能。

使用存储过程

执行存储过程

mysql称存储过程的执行为调用。

CALL productpricing (@pricelow
                    @pricehigh
                    @priceaverage);

执行名为productpricing的存储过程,它计算并返回产品的最低,最高和平均价格。

创建存储过程

例:返回产品平均价格的存储过程

CREATE PROCEDURE productpricing()
BEGIN 
    SELECT Avg(prod_price) AS priceaverage
    FROM products;
END;

这个存储过程叫productpriceing,用CREATE PROCEDURE productpricing()语句定义。

如果,存储过程接受参数,他们将在()中列举出来。此存储过程没有参数,但后面的()依旧需要你跟着。BEGIN和END用来限定存储过程体。

那么如何使用这个存储过程呢?

CALL productpricing();

删除存储过程

DROP  PROCEDURE productpricing;

使用参数

一般来说,存储过程是不显示结果的,而是把结果返回给你指定的变量

变量:内存中一个特定的位置,用来临时存储数据。

那么我们修改一手productpricing():

CREATE PROCEDURE productpricing(
    OUT pl DECIMAL(8,2),
    OUT ph DECIMAL(8,2),
    OUT pa DECIMAL(8,2)
    )
BEGIN 
    SELECT Min(prod_price)
    INTO p1
    FROM products;
    SELECT Max(prod_price)
    INTO ph
    FROM products;
    SELECT AVg(prod_price)
    INTO pa
    FROM products;
END;

:ice_cream: pl存储产品的最低价格。每个参数必须具有指定的类型,这里使用十进制值。关键字out指出这个参数是用来从存储过程传出一个值(返回给调用者)。

IN:传递给存储过程

OUT: 从存储过程传出

INOUT: 对存储过程传入和传出

CALL productpricing (@pricelow
                    @pricehigh
                    @priceaverage);
mysql的变量名必须以@开始

我们想要的结果就存储到了上面的三个变量里面了

SELECT @pricelow;

用上面的语句,就可以看到这个值了。

我们再写一个例子,用用IN和OUT。ordertotal接受订单号并返回该订单的合计

CREATE PROCEDURE ordertotal(
        IN onumber INT,
        OUT ototal DECIMAL(8,2)
)
BEGIN    
    SELECT Sum(item_price*quantity)
    FROM orderitems
    WHERE order_num = onumber
    INTO ototal;
END;

那要怎么样调用呢?

CALL ordertotal (20005,@total);

### 建立智能存储过程

--NAME:ordertatal
--Parameters:onumber = order number 
--            taxable = 0 if not taxable , 1 if taxable
--             ototal = order total variable

CREATE PROCEDURE ordertotal(
        IN onumber INT ,
        IN taxable BOOLEAN,
        OUT ototal DECIMAL (8,2)
        )COMMIT 'Obtain order total ,optionally adding tax'
        
BEGIN
 
     --Declare variable for total
     DECLARE total DECIMAL(8,2);
     --Declare tax percentage
     DECLARE taxrate INT DEFAULT 6;
     
     --Get the order tatal
     SELECT Sum(item_price*quantity)
     FROM orderitems
     WHERE order_num = onumber
     INTO tatal;
     
     --IS this taxble?
     IF taxable THEN 
             --Yes,so add taxrate to the total
             SELECT total+(total/100*taxrate) INTO total;
     END IF;
     
     --AND finally,save to out variable
     SELECT total INTO ototal;
     
 END;
  • -- 这玩意后面跟的是注释
  • DECLARE语句定义了两个局部变量,还支持设定默认值
  • SELECT语句的结果存储到了total
  • IF呢就是IF用法呗,真就执行。

检查存储过程

SHOW PROCEDURE STATUS LIKE '过程名';

会获得何时,谁创建等详细信息的存储过程列表。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
7月前
|
存储 Java 关系型数据库
java调用mysql存储过程
在 Java 中调用 MySQL 存储过程主要借助 JDBC(Java Database Connectivity)。其核心原理是通过 JDBC 与 MySQL 建立连接,调用存储过程并处理结果。具体步骤包括:加载 JDBC 驱动、建立数据库连接、创建 CallableStatement 对象、设置存储过程参数并执行调用。此过程实现了 Java 程序与 MySQL 数据库的高效交互。
|
6月前
|
存储 关系型数据库 MySQL
【YashanDB知识库】MySQL返回结果集的存储过程的改写方法
本文介绍了将MySQL存储过程改写至YashanDB的解决方案。由于MySQL存储过程可直接返回结果集,而YashanDB需通过返回SYS_REF_CURSOR的函数实现类似功能,因此需要对代码进行转换。示例中展示了如何将MySQL存储过程`proc1`改写为YashanDB函数,并调整JDBC应用代码以适配REF_CURSOR输出参数,从而正确获取查询结果。此方法确保了跨数据库场景下的兼容性与功能性。
|
10月前
|
存储 SQL NoSQL
|
11月前
|
存储 SQL 关系型数据库
MySql数据库---存储过程
MySql数据库---存储过程
137 5
|
11月前
|
存储 关系型数据库 MySQL
MySQL 存储过程返回更新前记录
MySQL 存储过程返回更新前记录
165 3
|
11月前
|
存储 SQL 关系型数据库
MySQL 存储过程错误信息不打印在控制台
MySQL 存储过程错误信息不打印在控制台
194 1
|
存储 关系型数据库 MySQL
Mysql表结构同步存储过程(适用于模版表)
Mysql表结构同步存储过程(适用于模版表)
125 0
|
存储 SQL 关系型数据库
MySQL 创建存储过程注意项
MySQL 创建存储过程注意项
109 0
|
存储 SQL 关系型数据库
MySQL存储过程和存储函数的使用
MySQL的存储过程和存储函数在功能和用法上有明显的区别。存储过程是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,通过指定名称和参数(如果有)来调用执行,可以返回多个值或结果集,但不直接返回值。而存储函数则是一个有返回值的特殊存储过程,它返回一个值或表对象,可以直接嵌入SQL语句中使用,如SELECT语句中。两者都是为了提高SQL代码的重用性和性能,但使用场景和方式有所不同。
4439 4
|
存储 SQL 关系型数据库
MySQL数据库进阶第四篇(视图/存储过程/触发器)
MySQL数据库进阶第四篇(视图/存储过程/触发器)

推荐镜像

更多