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

Вниз

Блокировки записей в многопользовательском режиме   Найти похожие ветки 

 
b-Ars ©   (2002-10-16 12:19) [0]

Зрасьте господа! Моя программа работает с расшаренными в локальной сети базами FoxPro. Для работы использую SQL-запросы. Возникает вопрос: как быть, если 2 пользователя редактируют одну запись - для TTable есть Lock`и, а для TQuery по-моему такого быть не может. Пожалуйста подскажите, каким образом решить проблему, только плиз, максимально простым путем, без премудростей, если есть только TQuery.


 
MsGuns ©   (2002-10-16 12:32) [1]

Обрабатывать события OnKeyViolate, если есть ключи и может быть вероятность добавления с разных компов записей с одинаковым набором ключей. Для обработки ситуации конфликта на одной записи служит постирование в защищенном режиме (try - except). При этом роли не играет, что используется: TTable или TQuery+Requestlive


 
b-ars ©   (2002-10-16 23:51) [2]

>MsGuns © (16.10.02 12:32) А пардон, OnKeyViolate это событие кого, TDatabase? Дык у меня нету его, он что обязательно нужен?


 
Zlob   (2002-10-17 08:15) [3]

А блокировка все равно делается в момент записи, при этом сверяется версия записи в зависимости от свойства UpdateMode.
И если версии не совпадают, то пользователь получает облом при Post.
Чем такой режим не устраивает ?


 
b-Ars ©   (2002-10-17 10:10) [4]

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


 
Zlob   (2002-10-17 10:18) [5]

При использовании TQuery вряд ли. Можно параллельно завести TTable, перед началом редактирования позиционироваться на соответствующую запись и делать Lock, При неудаче бросать Exception, но уж больно это муторно и криво. Либо использовать какую нибудь низкоуровневую функцию из BDE Api, надо поискать.


 
ЮЮ ©   (2002-10-17 10:19) [6]

И чего это за базы такие, что все пользователи бросаются править одну и ту же запись ? :-)


 
b-Ars ©   (2002-10-17 12:03) [7]

>ЮЮ © (17.10.02 10:19), этакий нездоровый интерес, но это обычные базы для экономистов, полей много, набивкой разные тети занимаются в разных кабинетах, поэтому случается, что это происходит одновременно :)))



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

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

Наверх




Память: 0.48 MB
Время: 0.019 c
1-21601
Oleg_V
2002-10-30 12:36
2002.11.07
Народ подскажите как заблокировать Alt+F4 в своей программе.


4-21861
Diamond Cat
2002-09-24 18:55
2002.11.07
куда исчезают ресурсы?


4-21874
FilSM
2002-09-25 18:11
2002.11.07
Определение IP адреса


1-21597
Higs
2002-10-30 12:47
2002.11.07
Обход всех контролов


4-21888
Slava V.
2002-09-27 17:59
2002.11.07
Запущена ли программа?