如何从 MySQL 函数中返回表


函数不能从 MySQL 函数中返回表。函数可以返回字符串、数字、字符等。要从 MySQL 中返回表,请使用存储过程,而不要使用函数。

我们先创建一个表 −

mysql> create table DemoTable696 (
   Id int,
   Name varchar(100)
);
Query OK, 0 rows affected (0.77 sec)

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

mysql> insert into DemoTable696 values(100,'Mike');
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable696 values(101,'Sam');
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable696 values(102,'Adam');
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable696 values(103,'Carol');
Query OK, 1 row affected (0.20 sec)

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

mysql> select *from DemoTable696;

这将产生以下输出 -

+------+-------+
| Id   | Name  |
+------+-------+
| 100  | Mike  |
| 101  | Sam   |
| 102  | Adam  |
| 103  | Carol |
+------+-------+
4 rows in set (0.00 sec)

以下是返回 MySQL 表的查询。

存储过程如下 −

mysql> DELIMITER //
mysql> CREATE PROCEDURE getResultSet(studId int )
   BEGIN
      select *from DemoTable696 where Id=studId;
   END
   //
Query OK, 0 rows affected (0.14 sec)
mysql> DELIMITER ;

现在,你可以使用 call 命令调用存储过程 −

mysql> call getResultSet(103);

这将产生以下输出 -

+------+-------+
| Id   | Name  |
+------+-------+
| 103  | Carol |
+------+-------+
1 row in set (0.00 sec)
Query OK, 0 rows affected (0.01 sec)

更新于: 2019-08-21

9K+ 浏览量

开启您的 职业

完成课程即可获得证书

开始使用
广告
© . All rights reserved.