Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2003.04.24;
Скачать: [xml.tar.bz2];

Вниз

deadlock на MS SQL 2000   Найти похожие ветки 

 
Clickmaker   (2003-04-04 13:09) [0]

При выполнении запроса типа "update <table> set <field> = "строка" where Object_ID = <id>" с помощью TQuery (BDE 5.11) в одной таблице, но для разных записей из разных потоков (и разных сессии БДЕ) очень часто вылезает такая гадость "A deadlock was detected.
Transaction (Process ID 53) was deadlocked on lock resources with another process and has been chosen as the deadlock victim.
General SQL error". Догадываюсь, что, судя по всему, 2 транзакции столкнулись лбами на одной таблице, но по идее блокировка не должна быть на всей таблице, а только на одной записи. Или я чего-то недопонимаю... Может кто решал такую задачку, подскажите, где грабли: БДЕ, MS SQL...


 
stone   (2003-04-04 13:56) [1]


> MS SQL

Но это может произойти только для одной записи из разных потоков. В твоем случае смотри уровень изоляции транзакций.


 
Clickmaker   (2003-04-04 14:04) [2]

Да на этот момент у меня уровень READ UNCOMMITTED. Но есть подозрение, что если явно не обернуть update в транзакцию, то сервер стартует неявную глобальную транзакцию, которая монопольно блокирует таблицу в диапазоне индекса, если where в update по индексному полю. Или я ошибаюсь?


 
stone   (2003-04-04 14:09) [3]


> если явно не обернуть update в транзакцию, то сервер стартует
> неявную глобальную транзакцию

Не скажу на счет глобальной, но неявная транзакция естественно стартуется.



Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2003.04.24;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.006 c
7-77180
plaha999
2003-03-06 10:39
2003.04.24
Работа с железом


7-77187
iusupp
2003-03-05 21:49
2003.04.24
Мастера ... можно играть и смотреть кино...?


3-76822
Мыш
2003-04-01 08:46
2003.04.24
Связь полей в таблицах


7-77192
dimkamai
2003-03-06 21:28
2003.04.24
Перехват переключения раскладки клавиатуры


14-77149
kostya2000
2003-04-08 17:40
2003.04.24
Во моник гад!





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский