Главная страница
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.02 c
1-21558
_saha_
2002-10-29 14:09
2002.11.07
ламерский вопрос


7-21835
AndreyS
2002-09-05 15:40
2002.11.07
Осциллографическая плата


3-21447
Youri
2002-10-21 11:09
2002.11.07
Ищу в базе!


7-21828
and_sp
2002-09-04 16:49
2002.11.07
Работа с портами в Windows NT


3-21427
Chak
2002-10-18 23:54
2002.11.07
Date&Time in ORACLE