如何从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)
阅读更多:MySQL 教程
极客教程