Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / как возвратить таблицу из функции / 10 сообщений из 10, страница 1 из 1
15.03.2005, 19:18
    #32961841
pepko
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
как возвратить таблицу из функции
Здравствуйте,

никак не пойму как правильно возвратить из функции таблицу-результат SELECT-а, то просит использовать RETURN NEXT, то ещё какие-то ошибки выдаёт.

В MS SQL Server 2000 это вообще елементарно выглядело:

Код: plaintext
...   RETURN SELECT * FROM mytable   ...

А здесь прямо ужас какой-то. Документация очень неинформативна.

Подскажите, пожалуйста, кто знает.

Володя
...
Рейтинг: 0 / 0
15.03.2005, 23:14
    #32962025
Pilot
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
как возвратить таблицу из функции
Код: plaintext
1.
2.
3.
4.
5.
CREATE FUNCTION getMyTable()
  RETURNS SETOF mytable AS
$BODY$
    SELECT * FROM mytable;
$BODY$
  LANGUAGE 'sql' VOLATILE;


Для корабля, который не знает куда плыть, нет попутного ветра...
...
Рейтинг: 0 / 0
16.03.2005, 11:07
    #32962609
pepko
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
как возвратить таблицу из функции
Большое спасибо!
Как мало, иногда, надо для счастья :-)
...
Рейтинг: 0 / 0
Период между сообщениями больше года.
25.08.2006, 18:09
    #33944056
sam21
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
как возвратить таблицу из функции
Столкнулся с этой же проблемой - возврата функции из таблицы. Делаю так, как здесь предложено:

CREATE FUNCTION getMyTable()
RETURNS SETOF mytable AS
$BODY$
RETURN SELECT * FROM mytable;
$BODY$
LANGUAGE 'sql';

Ошибок нет, но выдает пустую таблицу и пишет в messages:

row number -1 is out of range 0..-1
Total query runtime: 94 ms.
Data retrieval runtime: 15 ms.
0 rows retrieved.

Если посмотреть эту таблицу после выполнения процедуры, то данные там имеются.

В чем загвоздка?

Заранее благодарен.
...
Рейтинг: 0 / 0
25.08.2006, 18:25
    #33944092
Кифирчик
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
как возвратить таблицу из функции
убери RETURN
...
Рейтинг: 0 / 0
25.08.2006, 18:37
    #33944118
sam21
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
как возвратить таблицу из функции
Убираю return - пишет ошибку:
...
Рейтинг: 0 / 0
25.08.2006, 18:38
    #33944119
sam21
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
как возвратить таблицу из функции
ERROR: SELECT query has no destination for result data.
If you want to discard the results, use PERFORM instead.
...
Рейтинг: 0 / 0
25.08.2006, 20:46
    #33944282
Кифирчик
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
как возвратить таблицу из функции
попробуй с указанием схемы,
вот у меня аналогичная функция
Код: plaintext
1.
2.
3.
4.
CREATE OR REPLACE FUNCTION "schema1"."getusers" () RETURNS SETOF "schema1"."mens" AS
$body$
select * from schema1.mens;
$body$
LANGUAGE 'sql' VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;
вызов
Код: plaintext
SELECT * FROM schema1.getusers()
...
Рейтинг: 0 / 0
01.09.2006, 16:44
    #33959290
olden69
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
как возвратить таблицу из функции
наткнулся на аналогичную проблему
уж было решил, что Постгри такого никак не может, но, как оказалось, все намного веселее

в данном случае согласно мануалу решается так:

Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
CREATE FUNCTION getMyTable()
  RETURNS SETOF mytable%ROWTYPE AS
$BODY$
  DECLARE fnc_ret mytable%ROWTYPE;
BEGIN
  FOR fnc_ret IN SELECT * FROM mytable
  LOOP 
    RETURN NEXT fnc_ret;
  END LOOP;

  RETURN;
END;
$BODY$
LANGUAGE 'sql';
...
Рейтинг: 0 / 0
28.02.2007, 12:22
    #34360169
Tertium Organum
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
как возвратить таблицу из функции
это не выполняется!
решается это через row и на plpgsql
...
Рейтинг: 0 / 0
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / как возвратить таблицу из функции / 10 сообщений из 10, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]