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

Вниз

эксклюзтвный доступ в dbf...... проблема   Найти похожие ветки 

 
koks ©   (2003-05-29 11:30) [0]

Здравствуйте, уважаемые мастера!
Помогите мне пожалуйста вылечить одну ошибку:

with dmDataModule.TTMData do
begin
Close;
Exclusive := true;
Open;
Check(DBIPackTable(DBHandle, Handle, nil, szDBASE, true));
Close;
Exclusive := false;
end;

with dmDataMjdule.TTMassivs do
begin
Close;
Exclusive := true;
Open;
Check(DBIPackTable(DBHandle, Handle, nil, szDBASE, true));
Close;
Exclusive := false;
end;

первый вызов проходит нормально - табличка пакуется на ура. Второй вызов пишет ошибку - table is busy...

облазил всю программу - ну не открыта она. прогонял прогу без среды - все ровно.
Примечательно, что эти две таблицы открываются и вообще используются одновременно (синхронно). Соответственно ошибки при установлении эксклюзивного доступа должны либо быть у обоих либо не быть вообще. Так вот, рассуждая так я нашел одно отличие - на вторую таблицу идут ссылки из лукап-полей из одного запроса. Так вот, я ЗАКРЫВАЮ преварительно этот запрос... все равно table is busy... может надо еще чего с ним сделать (с запросом)


 
Соловьев ©   (2003-05-29 11:35) [1]

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


 
koks ©   (2003-05-29 17:29) [2]

логично, однако грубо


 
Соловьев ©   (2003-05-29 17:37) [3]

просто часто делать упаковку тебе все равно не надо - пусть пользователь подождет при запуске, вот и все.


 
sniknik ©   (2003-05-29 18:27) [4]

> Примечательно, что эти две таблицы открываются и вообще используются одновременно (синхронно).
синхронно т.е. в разных потоках? и в одной сессии? если так то пока работает DBIPackTable с одной таблицей монопольное открытие любой другой приведет к "table is busy". (ну так если рассуждать логично)

попробуй вторую первой паковать.


 
Serginio   (2003-05-29 20:04) [5]

А зачем тебе ее паковать. В фоксах есть индекс Deleted который хранит ссылки на удаленные записи и при добавлении записи находит таковой по индексу и использует ее. Это нормальная практика во всех БД.


 
Кулешов   (2003-05-30 12:43) [6]

Попробуй сделать так, мне помогло:
...
Table.ReadOnly:=False;
Table.Exclusive := True;
...



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

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

Наверх




Память: 0.48 MB
Время: 0.027 c
14-84717
PVOzerski
2003-06-05 13:51
2003.06.26
UDF к MySQL


1-84193
yaJohn
2003-06-11 17:52
2003.06.26
Нужно получать Idle сообщения


14-84724
ДиМАньяк
2003-06-05 16:19
2003.06.26
Win API


3-83886
Uran
2003-06-02 16:48
2003.06.26
DBF в рантайм.


1-84372
X~Man
2003-06-13 20:29
2003.06.26
Сохранение