Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности

Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
21.03.2001, 12:53
|
|||
|---|---|---|---|
|
|||
Блокировка таблиц транзакцией, чтоб ей жизни небыло! |
|||
|
#18+
MS SQL 7.0+Delphi5+ADO Коллеги, помогите плиз. Суть проблемы в следующем: Имеются 2 таблицы (Заголовки документов, детализация документов) Tab1(ID int, DocDescr char(15)), Tab2(Link_ID, DocDet char(20)). Связаны по полям ID-Link_ID. ID-автоинкримент. Некоторые записи из этих таблиц необходимо перенести в аналогичные (назовем их Tab1_1 и Tab2_1). Тело проседуры: CREATE PROCEDURE Transfer(@ADocID int) AS DECLARE @NewRefID int BEGIN TRAN INSERT Tab1_1 (DocDescr) SELECT DocDescr FROM Tab1 WHERE Tab1.ID=@ADocID SET @NewRefID=(SELECT MAX(ID) FROM Tab1_1) INSERT Tab2_1 (Link_ID,DocDet) SELECT Link_ID=@NewRefID, DocDet=Tab2.DocDet FROM Tab2 WHERE Tab2.Link_ID=@ADocID COMMIT TRAN Пользователь на форме отмечает в гриде необходимые накладные, а затем в цикле в ADOStoredProc передается ID перемещаемого документа. Так вот, во время этого циклического переноса Tab1_1 и Tab2_1 блокируются так, что из них даже не выполняется СЕЛЕКТ в аналайзере: "Your transaction (process ID #89) was deadlocked with another process and has been chosen as the deadlock victim. Rerun your transaction." Не говоря уже о попытках других пользователей сделать перемещение. Я, конечно упростил стуктуру таблиц. Там еще триггера висят- в общем один документ переносится секунд 10-15. Как сделать так, чтобы не ругалась, а? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=46&mobile=1&tid=1827162]: |
0ms |
get settings: |
11ms |
get forum list: |
16ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
41ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
30ms |
get tp. blocked users: |
2ms |
| others: | 269ms |
| total: | 389ms |

| 0 / 0 |
