Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.03.17;
Скачать: CL | DM;

Вниз

Какие записи блокированы?   Найти похожие ветки 

 
Roma111111   (2003-02-20 14:23) [0]

У меня D6 и Firebird 1. Программа многопользовательская. Пользователи с разных рабочих мест добавляют и редактируют разные таблицы (3 шт.). Как узнать, какие записи конкретной таблицы заблокированы другими пользователями? А то при одновременном UPDATE программа зависает...

Заранее благодарен ...


 
Alexandr ©   (2003-02-20 14:26) [1]

в параметрах транзакции поставь nowait


 
Roma111111   (2003-02-20 14:32) [2]

В IBTransact? Что будет происходить "грязное чтение"?


 
Johnmen ©   (2003-02-20 14:39) [3]

Разве в слове nowait есть хотя бы намек на dirty или read ?
:)))



 
Desdechado ©   (2003-02-20 15:00) [4]

блокировки на уровне таблицы с клиента не видны.
а если юзеры изменяют разные записи, то вообще никаких проблем не должно быть.


 
Roma111111   (2003-02-20 15:24) [5]

А nowait записывать в строку params?


 
Johnmen ©   (2003-02-20 15:29) [6]

Если IBX или FIB, то даблклик на (F)IBTransaction.


 
Roma111111   (2003-02-20 15:31) [7]

А что реально устанавливает этот параметр, не будут данные оного юзера писаться поверх другого?


 
Johnmen ©   (2003-02-20 15:37) [8]

Модифицировать версию записи при коммите не дожидаясь коммита от другой транзакции, работающей с версией той же записи...
Короче, ставь, и будет радостно...:)))


 
Roma111111   (2003-02-20 15:39) [9]

нет мне это не нужно. если запись заблокирована, ее трогать нельзя ...


 
Anatoly Podgoretsky ©   (2003-02-20 15:54) [10]

Roma111111 (20.02.03 14:23)
Как это зависает, у других не зависает, значит у тебя неправильно что сделано.

Roma111111 (20.02.03 15:31)
Это штатный режим менять записи отредактированные другим пользователем, для этого базы и предназначены.

Roma111111 (20.02.03 15:39)
Не трогай раз не хочешь.


 
passm ©   (2003-02-20 16:01) [11]

Roma111111 (20.02.03 14:23)> Делать транзакции как можно короче по времени. И ничего узнавать о заблокированных записях не надо, за исключением взаимных блокировок.
IMHO.


 
Johnmen ©   (2003-02-20 16:03) [12]

Про блокировки в истинном понимании забудь ! Их нет в IB.


 
Roma111111   (2003-02-25 11:58) [13]

Всем спасибо!!!
Я поставил IBTransact параметр "Snapshot (concurrency, nowait)" и теперь при попытке изменить "заблокированную" запись выдается Exception, который я благополучно обрабатываю.



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

Текущий архив: 2003.03.17;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.015 c
14-54313
zzet
2003-03-01 17:14
2003.03.17
Boot - вирус?


14-54235
@lex
2003-02-27 16:52
2003.03.17
Посчитать угол по 3 точкам


1-54029
KpeHgeJIb
2003-03-04 20:49
2003.03.17
Как получить список всех дочерных окон относящихся к пределенном.


1-53998
Vital28
2003-03-06 15:53
2003.03.17
Как программно кликнуть по кнопке или пунуту меню в своей проге ?


1-54035
dim-
2003-03-04 15:30
2003.03.17
как можно получить снимок с панели?