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

Добрый день, почему мне выдает: invalid transaction termination? CREATE OR REPLACE FUNCTION

place_order(
firstName VARCHAR(200), lastName VARCHAR(200), buyerEmail VARCHAR(200),
buyerPhone VARCHAR(30), book JSONB, freeTicket BOOLEAN, eventDate VARCHAR(20),
eventHour VARCHAR(10), orderTotal NUMERIC(8, 2)
) RETURNS INTEGER AS $$
DECLARE
place RECORD;
_order_id INTEGER;
counter INTEGER;
_show_id INTEGER;
_event_id INTEGER;
_available INTEGER;
_sold INTEGER;
BEGIN
INSERT INTO
purchase (name, surname, phone, email, guest)
VALUES
(firstName, lastName, buyerPhone, buyerEmail, freeTicket)
RETURNING
id INTO _order_id;
FOR place IN SELECT * FROM json_to_recordset(to_json(book)) AS seat (id INTEGER, title TEXT, quantity INTEGER) LOOP
counter := 0;
SELECT
s.id, s.event_id, b.qty_available INTO _show_id, _event_id, _available
FROM
event_shows s,
ticket_books b
WHERE
place.id = b.id AND
s.event_id = b.event_id AND
s.start_date::date = to_date(eventDate, 'DDMMYYYY')::date;
SELECT
COUNT(id) INTO _sold
FROM
ticket
WHERE
book_id = place.id AND
show_id = _show_id AND
showtime = eventHour;
IF
_available - _sold < place.quantity
THEN
ROLLBACK;
RETURN 0;
END IF;
WHILE counter < place.quantity LOOP
counter := counter + 1;
INSERT INTO
ticket (book_id, order_id, show_id, showtime, secret)
VALUES
(place.id, _order_id, _show_id, eventHour, random_string(6));
END LOOP;
END LOOP;
COMMIT;
RETURN _order_id;
END;
$$ LANGUAGE plpgsql;

2 ответов

14 просмотров

потому что ф-ции не умеют в контроль транзакций?

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

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

коллеги, добрый вечер! А никто не знает как модальная форма может себя закрыть? Ну допустим модальная форма определила, что смысла ей работать нет и хочет вернуть modalResult...
Михаил
83
Hi Everyone! To all Are you Looking for Interview Support at the Lowest Price? Look no further! Then contact us We offer Interview Support for a low cost variety of technol...
Rambabu Nallamilli
3
верно что я могу удалить эти addq и subq т.к. со стеком никакого взаимодействия нет (исключая call)?
Michael
16
А если изначально бот работал так : есть сайт онлайн школы. У каждого ученика свой кабинет. Где он авторизуется по своим данным. И уже в кабинете, на самом сайте делает оплату...
Денис 💡 Фрилансер
13
Добрый день Хочу начать обучение языку, не являюсь представителем it, буду благодарна за помощь, совсем пока не понимаю ничего) Подскажите, пожалуйста, где можно начать первы...
Sara Lala
23
средствами IBX как-то можно выполнить запрос insert ... returning?
Igor
31
А что ты вообще делаешь ?
Yesgoter
13
На работе пишем распределенное приложение, у которого сотни, если не тысячи настроек. Конфиги написаны на xml, расположены на разных хостах и должны быть согласованы друг с др...
Aleksandr Druzhinin
5
Hi there everyone Is there anyone who have not started hamster bot yet? I need only one, I'll be glad if you do this for me DM if you haven't yet
Mehrshad
53
Всем привет 🙂 Какая-то непонятная проблема у меня с видео, раньше такого не было. Загружаю видео с гугл диска именно в видео mp4 и меняю ссылку как положено вот она: https://d...
Ксюша|Верстка на Тильде|Дизайн 🦥
6
Карта сайта