广告
返回顶部
首页 > 资讯 > 数据库 >怎么在mysql存储过程中返回多个值
  • 653
分享到

怎么在mysql存储过程中返回多个值

2024-04-02 19:04:59 653人浏览 薄情痞子
摘要

本篇文章为大家展示了怎么在Mysql存储过程中返回多个值,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。mysql存储函数只返回一个值。要开发返回多个值的存储过程,需

本篇文章为大家展示了怎么在Mysql存储过程中返回多个值,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

mysql存储函数只返回一个值。要开发返回多个值的存储过程,需要使用带有INOUT或OUT参数的存储过程。咱们先来看一个orders表它的结构:

mysql> desc orders;
+----------------+-------------+------+-----+---------+-------+
| Field     | Type    | Null | Key | Default | Extra |
+----------------+-------------+------+-----+---------+-------+
| orderNumber  | int(11)   | NO  | PRI | NULL  |    |
| orderDate   | date    | NO  |   | NULL  |    |
| requiredDate  | date    | NO  |   | NULL  |    |
| shippedDate  | date    | YES |   | NULL  |    |
| status     | varchar(15) | NO  |   | NULL  |    |
| comments    | text    | YES |   | NULL  |    |
| customerNumber | int(11)   | NO  | MUL | NULL  |    |
+----------------+-------------+------+-----+---------+-------+
7 rows in set

然后嘞,咱们来看一个存储过程,它接受客户编号,并返回发货(shipped),取消(canceled),解决(resolved)和争议(disputed)的订单总数:

DELIMITER $$
CREATE PROCEDURE get_order_by_cust(
 IN cust_no INT,
 OUT shipped INT,
 OUT canceled INT,
 OUT resolved INT,
 OUT disputed INT)
BEGIN
 -- shipped
 SELECT
      count(*) INTO shipped
    FROM
      orders
    WHERE
      customerNumber = cust_no
        AND status = 'Shipped';
 -- canceled
 SELECT
      count(*) INTO canceled
    FROM
      orders
    WHERE
      customerNumber = cust_no
        AND status = 'Canceled';
 -- resolved
 SELECT
      count(*) INTO resolved
    FROM
      orders
    WHERE
      customerNumber = cust_no
        AND status = 'Resolved';
 -- disputed
 SELECT
      count(*) INTO disputed
    FROM
      orders
    WHERE
      customerNumber = cust_no
        AND status = 'Disputed';
END

其实,除IN参数之外,存储过程还需要4个额外的OUT参数:shipped, canceled, resolved 和 disputed。 在存储过程中,使用带有count函数的select语句根据订单状态获取相应的订单总数,并将其分配给相应的参数。按着上面的sql,我们如果要使用get_order_by_cust存储过程,可以传递客户编号和四个用户定义的变量来获取输出值。执行存储过程后,我们再使用SELECT语句输出变量值:

+----------+-----------+-----------+-----------+
| @shipped | @canceled | @resolved | @disputed |
+----------+-----------+-----------+-----------+
|    22 |     0 |     1 |     1 |
+----------+-----------+-----------+-----------+
1 row in set

结合实际应用,我们再来看下从PHP程序中调用返回多个值的存储过程:

<?php

function call_sp($customerNumber)
{
  try {
    $pdo = new PDO("mysql:host=localhost;dbname=yiibaidb", 'root', '123456');
    // execute the stored procedure
    $sql = 'CALL get_order_by_cust(:no,@shipped,@canceled,@resolved,@disputed)';
    $stmt = $pdo->prepare($sql);
    $stmt->bindParam(':no', $customerNumber, PDO::PARAM_INT);
    $stmt->execute();
    $stmt->closeCursor();
    // execute the second query to get values from OUT parameter
    $r = $pdo->query("SELECT @shipped,@canceled,@resolved,@disputed")
         ->fetch(PDO::FETCH_ASSOC);
    if ($r) {
      printf('Shipped: %d, Canceled: %d, Resolved: %d, Disputed: %d',
        $r['@shipped'],
        $r['@canceled'],
        $r['@resolved'],
        $r['@disputed']);
    }
  } catch (PDOException $pe) {
    die("Error occurred:" . $pe->getMessage());
  }
}
call_sp(141);

上述内容就是怎么在mysql存储过程中返回多个值,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: 怎么在mysql存储过程中返回多个值

本文链接: https://www.lsjlt.com/news/55569.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在mysql存储过程中返回多个值
    本篇文章为大家展示了怎么在mysql存储过程中返回多个值,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。mysql存储函数只返回一个值。要开发返回多个值的存储过程,需...
    99+
    2022-10-18
  • MySql 储存过程 多个结果返回解析
    当需要查询复杂的数据模型并返回多个结果集时,使用 MySQL 存储过程可以有效地优化性能。同时,在开发中使用 Mybatis 可以方便地调用 MySQL 存储过程并获取多个结果集。本文将介绍如何在 Mybatis 中调用 MySQL 存...
    99+
    2023-09-27
    mysql mybatis java
  • mysql存储过程返回多个结果集的示例
    这篇文章给大家分享的是有关mysql存储过程返回多个结果集的示例的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。mysql存储函数只返回一个值。要开发返回多个值的存储过程,需要使用...
    99+
    2022-10-18
  • mybatis调用mysql存储过程并获取返回值方式
    目录mybatis调用mysql存储过程并获取返回值1、mysql创建存储过程2、mybatis调用mybatis调存储过程遇到返回值null的坑mybatis调存储过程时返回值nu...
    99+
    2022-11-13
  • 怎么在python中利用return返回多个值
    这篇文章给大家介绍怎么在python中利用return返回多个值,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。python可以做什么Python是一种编程语言,内置了许多有效的工具,Python几乎无所不能,该语言通俗...
    99+
    2023-06-14
  • mysql怎么执行多个存储过程
    要执行多个存储过程,可以使用MySQL的CALL语句。以下是一个示例:```CALL 存储过程1();CALL 存储过程2();```其中,"存储过程1"和"存储过程2"是你要执行的两个存储过程的名称。你可以根据实际情况替换它们。每个C...
    99+
    2023-08-11
    mysql
  • Sql Server存储过程中如何调用存储过程接收输出参数返回值
    这篇文章将为大家详细讲解有关Sql Server存储过程中如何调用存储过程接收输出参数返回值,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。创建存储过程:AL...
    99+
    2022-10-18
  • 存储过程的使用(五)——(返回结果集/设置多个变量值)--遇到坑
    表如下: 表数据:https://pan.baidu.com/s/1e9dpnr8sYvq_8-E-h5RxJg 提取码:fpig 复制这段内容后打开百度网盘手机App,操作更方便哦 如上图就是给多个变量设置值,像单个变量的查询结果设...
    99+
    2021-11-19
    存储过程的使用(五)——(返回结果集/设置多个变量值)--遇到坑
  • mybatis调用mysql存储过程(返回参数,单结果集,多结果集)
    目录一、接收一个返回值注意事项:存储过程主要分成三类:二、接收list结果集三、返回多个结果集四、第二种配置也可以一、接收一个返回值 使用Map接收返回参数,output参数放在传入...
    99+
    2022-11-12
  • 怎么在PHP中实现MySQL存储过程
    这篇文章主要介绍了怎么在PHP中实现MySQL存储过程的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么在PHP中实现MySQL存储过程文章都会有所收获,下面我们一起来看看吧。一、MySQL存储过程简介MySQ...
    99+
    2023-07-05
  • MySQL中怎么使用存储过程
    MySQL中怎么使用存储过程,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 mysql存储过程存储过程(Stored  P...
    99+
    2022-10-18
  • mysql中怎么创建存储过程
    mysql中怎么创建存储过程,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。mysql创建存储过程和函数 一个存储程序是可以被存储在服...
    99+
    2022-10-18
  • MYSQL中怎么管理存储过程
    今天就跟大家聊聊有关MYSQL中怎么管理存储过程,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。查看存储过程函数名:存储过程:(注意字段name,ty...
    99+
    2022-10-18
  • SQL Server存储过程中怎么同时返回分页结果集和总数
    这期内容当中小编将会给大家带来有关SQL Server存储过程中怎么同时返回分页结果集和总数,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、内核层,通常也就是要查询的字...
    99+
    2022-10-18
  • 如果列中还存储了一些 NULL 值,MySQL COUNT() 函数会返回什么?
    当我们使用 MySQL COUNT() 函数对存储在也存储了一些 NULL 值的列中的值进行计数时,MySQL 会忽略 NULL 并仅返回非 NULL 值的结果。为了理解它,我们使用表“Employee”中的数据,如下所示 -mysql&g...
    99+
    2023-10-22
  • 怎么在mysql中查看存储过程的状态
    在mysql中查询存储过程状态方法:1.启动mysql;2.登录mysql数据库;3.进入数据表;4.执行命令查看状态;具体步骤如下:首先,在命令行中启动mysql服务;service mysql start mysql服务启动后,输入用户...
    99+
    2022-10-25
  • 怎么在mysql存储过程中使用case语句
    今天就跟大家聊聊有关怎么在mysql存储过程中使用case语句,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。除了if语句,mysql提供了一个替代的...
    99+
    2022-10-18
  • mysql存储过程中游标怎么用
    这篇文章将为大家详细讲解有关mysql存储过程中游标怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 DELIMITER $$USE `...
    99+
    2022-10-18
  • Python中怎么调用MySql存储过程
    本篇文章为大家展示了Python中怎么调用MySql存储过程,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Python调用MySql存储过程步骤一.数据库准备建立表view sourcep...
    99+
    2023-06-17
  • 怎么在JFinal中调用存储过程
    本篇文章为大家展示了怎么在JFinal中调用存储过程,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。创建储存过程无参数,无返回值--创建名为 PERSON_PROC 的无参数、无返...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作