powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / execute проблемки
2 сообщений из 2, страница 1 из 1
execute проблемки
    #38877487
crause
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
есть функция
когда пишу большой запрос начинаю путаться коде, ну а по истечению какого-то времени вообще могу забыть ху из ху
появилась идея все таки использовать EXECUTE, быть с этой функцией читать потом мне будет легче

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
CREATE OR REPLACE FUNCTION to_json(text, VARIADIC text[]) 
RETURNS text AS
$BODY$
DECLARE
 RESULT text;
 SQL text;
 COL text;
BEGIN
 SQL = $1;
 COL = array_to_string($2, '');

EXECUTE 'SELECT json_agg(row_to_json((SELECT COL FROM (SELECT '||COL||') AS COL))) FROM ('||SQL||') AS D' INTO RESULT;
RETURN RESULT;
END;
$BODY$
LANGUAGE plpgsql;



Код: sql
1.
SELECT to_json('SELECT * FROM test1','id, caption')


этот запрос выполняется все норм.

начал тестировать дальше, нужна дерево в json
Код: sql
1.
SELECT to_json('SELECT * FROM test1','id, caption, ((SELECT to_json('||'SELECT * FROM TEST2 where test2.test1_id=d.id'||', '||'id, test1_id, caption'||') )) ')


запрос вроде как должен отработать но фигушки, "ошибка в синтаксисе"

Гуру подскажите где ошибка.
...
Рейтинг: 0 / 0
execute проблемки
    #38877851
crause
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
во сне меня осенило. проснулся раньше на 30 минут.

Проблема решатся через ||()::text
...
Рейтинг: 0 / 0
2 сообщений из 2, страница 1 из 1
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / execute проблемки
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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