Гость
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Сломал голову. / 4 сообщений из 4, страница 1 из 1
07.11.2019, 17:37
    #39886352
комит
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сломал голову.
Добрый вечер.

Есть табличка:

Код: sql
1.
2.
3.
create temp table tmp_test (t text);
INSERT INTO tmp_test(t) VALUES ('1+2');
INSERT INTO tmp_test(t) VALUES ('3*2+5');




Как запросом достать из нее данные, чтобы получилось вычисление?

Т.е. чтобы вывод был
Код: sql
1.
2.
3
11



Уже сломал голову.
...
Рейтинг: 0 / 0
07.11.2019, 17:48
    #39886361
комит
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сломал голову.
Вот так выводит запросы, которые, если отдельно выполнять должны выдать результат:

SELECT t, ( 'SELECT '||t||';') FROM tmp_test



Но как получить результат этого запроса?
...
Рейтинг: 0 / 0
07.11.2019, 17:58
    #39886377
qwwq
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сломал голову.
комит,

это опасное занятие. но попробуйте что-то типа
Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
create or replace function execute_returning (_sql text) 
returns text 
as $$
declare _ret text;
begin 
	EXECUTE _sql  INTO _ret;
	return _ret;
end;
$$  language plpgsql;

with tmp_test (t) AS (VALUES ('1+2'),('3*2+5'),('log(7.31)'))
select execute_returning( 'select ('||t||')::text') from tmp_test



добавьте обработчики ошибок и т.п. по вкусу.
...
Рейтинг: 0 / 0
07.11.2019, 18:37
    #39886430
комит
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сломал голову.
qwwq
комит,

это опасное занятие. но попробуйте что-то типа
Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
create or replace function execute_returning (_sql text) 
returns text 
as $$
declare _ret text;
begin 
	EXECUTE _sql  INTO _ret;
	return _ret;
end;
$$  language plpgsql;

with tmp_test (t) AS (VALUES ('1+2'),('3*2+5'),('log(7.31)'))
select execute_returning( 'select ('||t||')::text') from tmp_test



добавьте обработчики ошибок и т.п. по вкусу.



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


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