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

Вниз

эксклюзтвный доступ в 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;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.038 c
1-84289
Александр из Минска
2003-06-07 21:34
2003.06.26
I/O error 32


14-84578
wicked
2003-06-08 19:34
2003.06.26
CodeGuard.....


3-84017
Belkova
2003-05-30 20:51
2003.06.26
windows2000 и транзакции


1-84392
VISA
2003-06-09 13:45
2003.06.26
Замена цвета картинки в TImageList


14-84589
Кен
2003-06-07 06:05
2003.06.26
Как создать пользовательский мод для мод для Unreal Tournament





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский