![]() |
Модераторы: skyboy |
![]() ![]() ![]() |
|
_prishelec_ |
|
||||||||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 24.11.2007 Репутация: нет Всего: нет |
Всем добрый день!
Имеем к примеру таблицу:
Поле state принимает одно из двух значений: 0/1; Оно отвечает за то, обрабатывается ли в данный момент времени текущая запись. Нечто вроде флага блокировки. У меня имеется два оператора:
Смысл должен быть такой: если мы находим запись, то должны эту запись по ее id заблокировать. ------ К примеру нам select вернул запись с id = 1. Мы должны сделать “
Клиентов большое множество, которые работают с текущей БД. Как сделать так чтобы никакой другой клиент не вклинился между select и update? Пробовал транзакции (таблицы соответственно перевел в innodb). Транзакция
Не помогает. Запись должна быть заблокирована, до тех пор, пока она обрабатывается. А потом тот же клиент (прога , который ее обработает, устанавливает поле state в 1. Раньше делал наоборот, сначала update по определенному условию (в дополнительное поле записывал уникальный GUID сгенеренный клиентом), и поэтому GUID делал выборку. Было все ок. Но ощущулась нагрузка на БД. Заранее спасибо! |
||||||||
|
|||||||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Самое простое - собрать два запроса в один. Или нормально настроить транзакции, задать уровень изоляции. -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
Zloxa |
|
|||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
при serializable, емнип, на блокировке должен будет встать апдейт а не конкурирующий селект -------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
|||
|
||||
Akina |
|
||||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
в
? ![]() -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
||||
|
|||||
_prishelec_ |
|
||||||||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 24.11.2007 Репутация: нет Всего: нет |
Не выйдет .Все это находиться в хранящейся процедуре. Добавлено @ 17:02
Пробовал
Тоже непомогает. вобще сама процедура вот
Правда ее разбирать не советую, а то еще мозг сломается перед НГ. ![]() Я ее так для сюда вставил. Это сообщение отредактировал(а) _prishelec_ - 29.12.2010, 17:09 |
||||||||
|
|||||||||
Zloxa |
|
||||||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
Да, если я правильно помню, при сериалайзе сессия 1 select сессия 2 select сессия 1 update - встает потому что сессия 2 накинула шаредлок. сессия 2 update - встает потому что сессия 1 накинула шаредлок. дедлок. Добавлено @ 17:11 чота я засомневался что именно так и будтет, но в том что чтения не будут блокировать чтения я еще не усомнился ![]() Добавлено через 11 минут и 24 секунды единственное что мне приходит в голову - фиктивный аптдейт с целью блокировки записи. но я абсолютно не знаком с матчастью и бестпрактис - маськи. Это сообщение отредактировал(а) Zloxa - 29.12.2010, 17:13 -------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
||||||
|
|||||||
Akina |
|
||||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Я так понимаю, что domain_id > 0 - это проверка, найдена запись или нет, верно? тогда почему бы не
? -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
||||
|
|||||
_prishelec_ |
|
||||||||||||||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 24.11.2007 Репутация: нет Всего: нет |
Мне тогда придется два раза использовать сложные запросы. domain_id > 0 - это проверка, найдена запись или нет Да, верно. У меня так раньше и было. Добавлено через 37 секунд
Т.е. у меня вложенный второй select рубит транзакцию? |
||||||||||||||
|
|||||||||||||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Гм... это ещё почему? я вижу ОДИН основной апдейт, и внутри него ОДИН вложенный селект... где второй? PS. Вас не учили цитировать только то, что действительно нужно, а не всё, что сказано? -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
_prishelec_ |
|
||||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 24.11.2007 Репутация: нет Всего: нет |
Кста не факт, что в процедуре такая фишка прокатит. Но попробую. У меня в первый селект вложен второй.Но суть чтоб это прокатило в процедуре. Добавлено @ 01:43 Не пашет, что и следовало ожидать
Это сообщение отредактировал(а) _prishelec_ - 30.12.2010, 01:44 |
||||
|
|||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Пока не вижу оснований для возникновения проблем... -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
_prishelec_ |
|
||||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 24.11.2007 Репутация: нет Всего: нет |
Всех с новым годом! Это я имел ввиду провотэто: Да, если я правильно помню, при сериалайзе сессия 1 select сессия 2 select сессия 1 update - встает потому что сессия 2 накинула шаредлок. сессия 2 update - встает потому что сессия 1 накинула шаредлок. Всех с новым годом! Это я имел ввиду провотэто: Да, если я правильно помню, при сериалайзе |
||||
|
|||||
![]() ![]() ![]() |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | MySQL | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |