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

Коллеги, вопрос по поводу pgx транзакций и архитектуры приложения: собственно первый

вопрос, в pgx методы обращения к базе данных такие как queryrow например можно писать от conn если не нужна транзакция, а можно от tx если нужна, так вот вопрос, можно ли написать методы с конкретными запросами так, чтобы их можно было и по отдельности применить и в рамках транзакции?
Второй вопрос где правильнее размещать логику транзакций, на уровне DAL или на уровне сервиса?

13 ответов

11 просмотров

на первый вопрос ответ да, если пошаманить с интерфейсами

1. Можно, пишите вызов в транзакции или вне 🙂 2. На уровне сервиса, конечно... (не совсем понятно, что имеется в виду, конечно, тк сервисы — это то, что сервирует (то есть почти все в проекте, но ответ выше от предположения, что под сервисом понимается сценарий вашего бизнес-контекста )

1. Самое простое - передавать транзакцию *tx в метод с запросом (или в его объект) и там проверять на nil перед вызовом. Ну или интерфейс оформить, как предлагали.

Есть ещё спорное решение спрятать транзакцию в контекст

распределённые транзакции? temporal.io!

Alexey Mayshev
Есть ещё спорное решение спрятать транзакцию в кон...

нужен транзакционный менеджер для го. я его уже год жду. щас напишут, что уже бы написал. и написал, но выкладывать стыдно))

Andrew Ka2
распределённые транзакции? temporal.io!

Вообще сути не не понял и вкинул не понятно что 🤡

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

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

Ребят в СИ можно реализовать ООП?
Николай
33
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный  TFilestream  не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
16
добрый день. Подскажите, есть сайт на 1.4.7 и я хочу обновиться, особо ничего не меняя. мне выбирать версию 1.4.35 или третью ветку? и можно ли обновлять "как есть", или нужно...
Digital Cat
12
У меня задача: написать брокер сообщений. Очереди и потребители. Очереди поддерживают приоритеты. Очередь отдает сообщения, только обработчикам с соответствующими характеристи...
Aleksandr Filippov
2
народ, плиз хелп, всю голову сломал себе уже... разве может быть так, что GetProcAddress( GetModuleHandle( "kernel32.dll" ), "SetThreadDescription" ) вернёт ненулевое значение...
Iluha Companets
12
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный TFilestream не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
8
Коллеги, я тут для личных нужд пошел ставить MQTT сервер, пощупал mosquitto, но ужаснулся отсутствию такой банальности, как HTTP API для посмотреть список топиков. А тут что,...
Maksim Lapshin
14
Карта сайта