172 похожих чатов

Всем привет. Есть вот такая красивая функция CREATE OR REPLACE FUNCTION app.create_multiple_tables

(loc_id uuid, number_of_tables int)
RETURNS boolean AS $$
BEGIN
IF number_of_tables > 0 AND ((current_setting('jwt.claims.role', true)::text = 'app_supervisor')
OR (current_setting('jwt.claims.person_id', true)::uuid IN (
SELECT b.owner_id FROM app.business b
JOIN app.location l ON
b.id = l.business_id
WHERE l.id = loc_id
)))
THEN
DELETE FROM app.location_table WHERE location_id = loc_id;
INSERT INTO app.location_table (location_id, id)
SELECT loc_id, generate_series(1,number_of_tables);
RETURN true;
ELSE
RETURN false;
END IF;
END;
$$ LANGUAGE plpgsql SECURITY DEFINER;

Все работает отлично, однако хочется возвратить SETOF app.location_table. Делаем DECLARE temp_table RECORD и вместо RETURN true RETURNING * INTO temp_table; Ошибка RETURN cannot have a parameter in function returning set Может кто подскажет?

2 ответов

13 просмотров

Во-первых — не работает оно "отлично" (если Вам на самом деле нужна security, а не её имитация). См. "Writing SECURITY DEFINER Functions Safely" вот тут https://www.postgresql.org/docs/current/sql-createfunction.html > Ошибка RETURN cannot have a parameter in function returning set Может кто подскажет? Возвраты из SRF действительно работают не так — в них RETURN просто выходит из функции. См. https://www.postgresql.org/docs/current/plpgsql-control-structures.html#PLPGSQL-STATEMENTS-RETURNING ("RETURN NEXT and RETURN QUERY").

Похожие вопросы

Обсуждают сегодня

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Привет, запускаю werf в dind в k8s, получаю ошибку на этапе build/beforeSetup: /.werf/stapel/embedded/bin/bash: /.werf/scripts/5898bdfe5214357d3706b879cc8d3d78460fb379607cbd...
florius0
7
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Ошибка: segmentation fault (core dumped) Код: pastebin.com/BEsNNSSV Сообщение от компилятора: отсутствует ОС: Arch Linux Ядро: x86_64 Linux 6.9.7-arch1-1 Процессор: Intel Cele...
sec
4
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
Добрый день, чат. Мне в очередь из других RabbitMQ по shovel валятся метрики в формате текста для Prometheus. Помогите пожалуйста подружить RabbitMQ и Prometheus, чтобы он (...
Aleksey
4
Карта сайта