如何從 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)
廣告