|
0 / 0 / 0
Регистрация: 19.03.2013
Сообщений: 24
|
|||||||
Транзакции и блокировки14.11.2016, 14:49. Показов 1085. Ответов 3
Метки нет (Все метки)
Привет. Есть две транзакции:
Если T2: 1) READ UNCOMMITTED - дедлока не происходит. 2) REPATABLE READ - дедлок (T1 удерживает блокировку X на table_1, T2 удерживает блокировку S на table_2 и не дает T1 установить X блокировку на table_2) Вопрос: Почему в первом случае дедлока не происходит, а во втором происходит, ведь T1 удерживает блокировку X на table_1 в обоих случаях (не должна давать T2 создать темповую таблицу)? Ведь известно, что X блокировка не дает возможности установить другие блокировки (ни S ни X). С одной стороны, ответ на этот вопрос очевиден - READ UNCOMMITED позволяет читать не зафиксированные изменения, но с другой, как X блокировка это позволяет сделать? В общем, в моей голове конфликтуют две темы, "транзакции" и "блокировки". Прочел массу материала, но исчерпывающей информации так и не нашел. Что я упускаю из всего этого?
0
|
|||||||
| 14.11.2016, 14:49 | |
|
Ответы с готовыми решениями:
3
Транзакции и блокировки Firebird транзакции и блокировки записей Транзакции |
|
25 / 25 / 7
Регистрация: 27.02.2013
Сообщений: 113
|
|
| 15.11.2016, 06:36 | |
|
1. насколько я знаю, MySQL вложенные транзакции не поддерживает. А у Вас транзакция T2 вложена в транз. T1.
2. REPEATABLE READ - это повторное чтение, т. е. при повторном чтении транзакция видит те же данные. И еще пока Т1 не закончится, блокировки не снимутся. 3. READ UNCOMMITTED - это фактически отсутствие всяких блокировок.
0
|
|
|
0 / 0 / 0
Регистрация: 19.03.2013
Сообщений: 24
|
|||
| 15.11.2016, 09:24 [ТС] | |||
0
|
|||
|
25 / 25 / 7
Регистрация: 27.02.2013
Сообщений: 113
|
|
| 15.11.2016, 12:17 | |
|
Почему в первом случае дедлока не происходит, а во втором происходит, ведь T1 удерживает блокировку X на table_1 в обоих случаях (не должна давать T2 создать темповую таблицу)?
Но транзакция T2 только читает данные, делает выборку, она не обновляет данные. Поэтому: Если T2 имеет уровень изоляции READ UNCOMMITTED, то она может прочитать т. table_1 (по чтению эта таблица доступна, она не доступна по записи) и соединить ее с т. table_2, которая тоже доступна по чтению. Если T2 имеет уровень изоляции REPEATABLE READ, то транз T2 пытается установить блокировки на таблицы table_1 и table_2, но они уже заблокированы транзакцией T1. Вот и происходит deadlock.
0
|
|
| 15.11.2016, 12:17 | |
|
Помогаю со студенческими работами здесь
4
транзакции Транзакции
Транзакции Транзакции Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем.
. . .
|