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 ответов

16 просмотров

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

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

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

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
32
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
25
Книга Юрова В.И пойдёт для обучения?
Botsman
24
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Подскажите пожалуйста, а я могу вот такую штуку использовать? rpc, только реализованное в реббите https://www.rabbitmq.com/tutorials/tutorial-six-php ( или https://habr.com/ru...
Artyom
11
а мы ещё не созрели до того, чтобы создать отдельный чатик про настройку редакторов?
Cheese Syrowiecki
16
И ещё вопрос: можно ли типа как на дос как-то запариться и с помощью прерываний выводить текст, вместо функции printf ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
34
Всем привет! У меня почему-то по-разному отображается TListView в Debug и Release режимах (FireMonkey)! При запуске под Win приложения TListView заливается программо. в Debug ...
Александр COM
8
Ладно, ещё тупого спрошу. Код должен банально вывести значение регистра на консоль, на деле же не выводя ничего, просто оставляя нерабочую консоль (открыта, ничего не написан...
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
25
Парни, спасайте. RAD Studio 12 творит какую-то дичь. У меня есть метод (event), который вызывает другой метод, т.е. он состоит из 1-й строки вызова. Ставлю бряк на event, запу...
Eugene Krasnikov (ᴊɪɴ x)
3
Карта сайта