Sobes.tech
Back to questions
Middle+
7

В чём основная проблема данной реализации BEGIN; CREATE TABLE sneakers ( id SERIAL PRIMARY KEY, design JSON NOT NULL ); CREATE OR REPLACE FUNCTION process_sneaker_order(sneaker_id INTEGER) RETURNS VOID AS $$ BEGIN UPDATE sneakers SET design = jsonb_set(design, '{status}', '"Processed"') WHERE id = sneaker_id; END; $$ LANGUAGE plpgsql; INSERT INTO sneakers (design) VALUES ('{"colors":"red,blue", "status":"Pending"}'); PERFORM process_sneaker_order(1); -- COMMIT;

Companies where asked
МТС БанкМТС Банк

Answer from AI

sobes.tech AI

Основная проблема данной реализации — отсутствие явного коммита транзакции. В коде начинается транзакция с BEGIN;, создаются таблица и функция, затем вставляется запись и вызывается функция обновления, но строка с COMMIT; закомментирована. Это значит, что изменения не будут зафиксированы в базе, и все операции откатятся при завершении сессии.

Кроме того, использование jsonb_set с типом json может привести к ошибкам, так как функция работает с jsonb. Лучше сразу объявить столбец design как jsonb.

Пример исправления:

BEGIN;

CREATE TABLE sneakers (
  id SERIAL PRIMARY KEY,
  design JSONB NOT NULL
);

CREATE OR REPLACE FUNCTION process_sneaker_order(sneaker_id INTEGER) RETURNS VOID AS $$
BEGIN
  UPDATE sneakers SET design = jsonb_set(design, '{status}', '"Processed"') WHERE id = sneaker_id;
END;
$$ LANGUAGE plpgsql;

INSERT INTO sneakers (design) VALUES ('{"colors":"red,blue", "status":"Pending"}');

PERFORM process_sneaker_order(1);

COMMIT;

Также стоит учитывать, что создание таблиц и функций обычно делают вне транзакций, которые обрабатывают данные, чтобы избежать блокировок и ошибок в продакшене.