如何使用 OUT 参数/在 MySQL 存储过程中通过 SELECT 从表中读取数据?


为此,你可以使用 SELECT INTO。我们首先创建一个表 −

mysql> create table DemoTable1860
     (
     Amount int
     );
Query OK, 0 rows affected (0.00 sec)

使用 insert 命令在表中插入一些记录 −

mysql> insert into DemoTable1860 values(1590);
Query OK, 1 row affected (0.00 sec)
mysql> insert into DemoTable1860 values(410);
Query OK, 1 row affected (0.00 sec)
mysql> insert into DemoTable1860 values(3000);
Query OK, 1 row affected (0.00 sec)

使用 select 语句显示表中的所有记录 −

Mysql> select * from DemoTable1860;

这将产生以下输出 −

+--------+
| Amount |
+--------+
|   1590 |
|    410 |
|   3000 |
+--------+
3 rows in set (0.00 sec)

以下是创建存储过程和使用 OUT 参数的查询 −

mysql> delimiter //
mysql> create procedure use_of_out_parameter(out TotalAmount int)
     begin
     select sum(Amount) into TotalAmount from DemoTable1860;
     end
     //
Query OK, 0 rows affected (0.00 sec)
mysql> delimiter ;

使用 call 命令调用存储过程 −

mysql> call use_of_out_parameter(@TotalAmount);
Query OK, 1 row affected (0.00 sec)

现在你可以使用参数变量 −

mysql> select @TotalAmount;

这将产生以下输出 −

+--------------+
| @TotalAmount |
+--------------+
|         5000 |
+--------------+
1 row in set (0.00 sec)

更新于: 26-Dec-2019

476 次浏览

开启你的 职业生涯

完成课程以获得认证

开始吧
广告