41 / 40 / 23
Регистрация: 10.03.2012
Сообщений: 374

Взаимная блокировка транзакций

29.04.2014, 19:10. Показов 3342. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Можно ли каким-либо образом на одном компьютере запустить две транзакции, которые будут блокировать друг друга?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.04.2014, 19:10
Ответы с готовыми решениями:

Взаимная блокировка потоков
В одной из моих программ, наблюдается взаимная блокировка потоков. Судя по всему это происходит из-за обращения к SysListView32 из...

Не срабатывает взаимная блокировка
Изучаю многопоточность при запуски данного кода, всегда выводится два потока, компилятор никогда не блокируется,

Мьютексы, взаимная блокировка процессов
процесс1 два раза посылает данные процессу2 на обработку while(i!=2) { pthread_mutex_unlock(mptr); ...

7
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
29.04.2014, 19:16
Транзакции и содержащиеся в них инструкции обрабатываются сервером, которому абсолютно все равно с каких компьютеров эти самые транзакции были запущены.
0
41 / 40 / 23
Регистрация: 10.03.2012
Сообщений: 374
29.04.2014, 19:22  [ТС]
invm, можно ли тогда заставить две транзакции выполняться одновременно? Если написать их в одном запросе, они выполняются последовательно. Вообще можно ли каким-то образом создать хоть какую-то взаимную блокировку?
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
29.04.2014, 19:32
Лучший ответ Сообщение было отмечено RocBoy-D как решение

Решение

RocBoy-D, Смоделировать работу транзакций
1
41 / 40 / 23
Регистрация: 10.03.2012
Сообщений: 374
30.04.2014, 02:47  [ТС]
invm, придумал такие варианты взаимных блокировок:

T-SQL
1
2
3
4
5
6
7
8
9
10
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRAN
    UPDATE оценка_товара
    SET оценка = оценка + 1
    WHERE оценка < 10; 
    WAITFOR DELAY '00:01:00'
    DELETE
    FROM оценка_товара
    WHERE оценка = 10;
COMMIT TRANSACTION
и
T-SQL
1
2
3
4
5
6
7
8
9
10
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRANSACTION
    UPDATE сотрудник
    SET Адрес_электронной_почты = 'alnemov@yahoo.com'
    WHERE Табельный_номер = 107;
    WAITFOR DELAY '00:01:00';
    DELETE
    FROM оценка_товара
    WHERE оценка < 10;
COMMIT TRANSACTION
А как теперь правильно избавиться от этой взаимной блокировки? Нашел несколько вариантов:
1) повысить уровень изоляции до SERIALIZABLE
2) использовать hint - HOLDLOCK
3) поменять местами запросы во второй транзакции.
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
30.04.2014, 09:21
RocBoy-D, в вашем примере нет взаимоблокировки.
0
41 / 40 / 23
Регистрация: 10.03.2012
Сообщений: 374
30.04.2014, 11:41  [ТС]
invm, извиняюсь, я не те запросы выставил. Вроде здесь должна быть взаимоблокировка:

T-SQL
1
2
3
4
5
6
7
8
9
10
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRANSACTION
    UPDATE оценка_товара
    SET оценка = оценка + 1
    WHERE оценка < 10;
    WAITFOR DELAY '00:01:00';
    UPDATE сотрудник
    SET Телефон = '079455819'
    WHERE Табельный_номер = 107;
COMMIT TRANSACTION
и
T-SQL
1
2
3
4
5
6
7
8
9
10
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
BEGIN TRANSACTION
    UPDATE сотрудник
    SET Адрес_электронной_почты = 'alnemov@yahoo.com'
    WHERE Табельный_номер = 107;
    WAITFOR DELAY '00:01:00';
    DELETE
    FROM оценка_товара
    WHERE оценка < 10;
COMMIT TRANSACTION
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
30.04.2014, 12:02
Для приведенного примера способ лечения только один: обеспечить одинаковый порядок обращения к таблицам.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.04.2014, 12:02
Помогаю со студенческими работами здесь

Многопоточность Java (Взаимная блокировка)
Есть пример public class Student { private ArrayList friends = new ArrayList(); public synchronized ArrayList getFriends() ...

Не понимаю вырезку из книги (Взаимная блокировка)
Читаю книгу Энтони Уильямся &quot;Паралельное программирование на С++&quot;. Но я не совсем понимаю следующий кусок (на картинке). Я понимаю...

Взаимная блокировка приложений с использованием семафоров
Доброго времени суток всем! Имеется такое задание: Искусственно создать взаимную блокировку потоков с использованием 2 объектов типа...

Почему происходит взаимная блокировка потоков?
Код из Гербердта Шилдта, глава 11, класс Deadlock // An example of deadlock. class A { synchronized void foo(B b) { String...

Блокировка клавиши при нажатии в одной форме и блокировка в другой, третьей
Здравствуйте нужно что бы при вызове помощи в 1ом вопросе она блокировалась во 2ом вопросе,подскажите как сделать. Вам нужно...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru