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

Есть вопрос по поводу паттерна взаимодействия с базой. Есть приложение, сервер

которого работает по модели запрос-ответ. (На протяжении пользовательской сессии это один запрос на сервер раз в 2-5 секунд, на каждый запрос - 3-5 запросов в базу). На каждый запрос могут срабатывать разные системы логики. Например, какие-то параметры объекта должны изменяться по времени, но вместо того, чтобы каждую минуту ходить по всей таблице и менять числа по таймеру, мы просто обновляем их, когда к нему кто-то стучится, используя поле last_update. Или ещё, на каждый запрос пользователя, вне зависимости от того, что это запрос, отправляем ему вдовесок все новые нотификации, которые он должен получить.

Насколько разумно в архитектуре приложения для каждого запроса создавать БД-транзакцию и потом передавать объект, представляющий эту транзакцию по всем вызовам, чтобы если что-то свалилось, не оставлять данные в полу-изменённом состоянии? Насколько часто такой подход применяется?

2 ответов

12 просмотров

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

Постоянно такой подход применяется. Разные фреймворк вроде Django могут даже за пользователя открывать транзакцию до вызовоа его кода и закрывать после ,если пользователь сам ее не закрыл

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

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

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
28
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
День добрый, подскажите пожалуйста, есть ли какой-то способ сказать ребару не компилировать определённое приложение? Всю доку их перечиатл ничего подобного не нашёл
Кирилл
14
Народ! Впервые клиенту пришло письмо от РКН, у вас, дескать, есть яндекс метрика, а нигде не написано, что вы ее юзаете. Никто не сталкивался?
Sasha Beep
10
Добрый вечер. Хочу чтобы у меня в классе поле было функцией, которая возвращает строку. Делаю так: interface ... TGetOutPath = function : String of object; ... protec...
Kirill Filippenok
12
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
В clientsettings есть поле client_rates. В поле pagebuilder. Как получить то его?)
Andrey K
8
Здравствуйте, хочу сделать HelloWorld в консоли Дельфи, но функция API ничего не выводит, что я делаю не так? program Hello; {$APPTYPE CONSOLE} uses System.SysUtils, WinAPI.Wi...
Sergey Vinogradov
20
Вопрос на перед, на следующую пятницу. Сколько строк кода можно вешать на одного программиста, понятно что если проект хорошо написан то можно и миллион. Но есть же где то пре...
AlekseyK Kluchnikov
31
Немного оффтопа: а кто на чем сидит для осдева в плане ide/редактора? Последнее время сидел на vscode, но я его прям не могу нормально воспринимать, перешел на сlion, но меня...
Evg Resh
29
Карта сайта