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

Как делать в вапоре при сохранении в бд лок таблицы?

8 ответов

31 просмотр

это вообще довольно характерная тема. ты точно уверен, что тебе это нужно? остальные клиенты ведь будут ждать (а они, может, вовсе по другим вопросам в таблице). и потом, зависит от базы. в мусе и постгре это ощутимо разные процедуры. ну и самое главное — тебе мало залочить таблицу, нужно еще её разлочить как при положительном исходе, так и при отрицательном. это не самая тривиальная задача, я тебе скажу.

Dmytro- Автор вопроса
Kirill Titov
это вообще довольно характерная тема. ты точно уве...

А что тогда делать, чтобы избежать race condition?

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

Dmytro
А что тогда делать, чтобы избежать race condition?

Создай тупо глобальную переменную Bool, и пропусти свой метод через нее. Пока не true обращаться к базе нельзя. Или у тебя проект уже на миллион долларов?

Dmytro- Автор вопроса
Kirill Titov
транзакции изучать, епта. лочить таблицу нужно тол...

Насколько понял, у бд есть своя очередь для транзакций?

Dmytro
Насколько понял, у бд есть своя очередь для транза...

Неправильно было бы называть это очередью для транзакций. В базах данных имеет место механизм сериализации, из названия подразумевается организация последовательности доступа к ресурсам. Как правило, если запрос пытается получить доступ к ресурсу (ну, записи в базе), который уже эксклюзивно занят другим процессом, то он получает отлуп. Муся и постгре почему-то называют это дедлоком, что неверно, это ведь всего лишь таймаут сериализации. ЖДАТЬ, пока доступ освободится, не надо (ты же занимаешь тред), а вот поретраить этот запрос очень даже можно (и нужно), только не до бесконечности

Dmytro- Автор вопроса
Kirill Titov
Неправильно было бы называть это очередью для тран...

Может не увидел вопрос, повторю Я вот одного не могу понять - вот у меня 50 одновременных запросы на добавление, и в каждом считается количество в группе. Тоесть, для одного из запросов надо будет 50 раз повторить?

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

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

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
Подскажите, а есть vault lite или ченить такое?) А то нужен вольт для похода в вольт, но весит он ~500 мб) как-то многовато для парочки запросов ))
Alexandr Orloff
17
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
Здравствуйте! Я вот на stepic решаю задачи на хаскеле https://stepik.org/lesson/8443/step/8?unit=1578 мой код import Data.List (isInfixOf) removing :: String -> [String] ->...
E
10
Камрады, кто тесно работал с vtv, хотел уточнить. Ширина column задаётся жёстко на этапе создания дерева или можно в рантайме ее менять программно (не мышкой)?
Ed Doc
10
да ладно ... что там неочевидного ? глянуть в исх-ки датасета и/или кверика чтобы понять в каком месте и как выполняется обращения к св-вам blablaSQL - минутное дело, даже е...
Сергей
7
Здесь для arm кто-нибудь кодит ?
Nothing
52
Карта сайта