Поиск по сайту:

Как вернуть таблицу из функции 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 ;

Теперь вы можете вызвать хранимую процедуру с помощью команды вызова:

mysql> call getResultSet(103);

Это даст следующий результат:

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

Статьи по данной тематике: