Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  4 649

•  TDictionary Custom Sort  6 652

•  Fast Watermark Sources  6 433

•  3D Designer  9 372

•  Sik Screen Capture  6 762

•  Patch Maker  7 159

•  Айболит (remote control)  7 164

•  ListBox Drag & Drop  6 019

•  Доска для игры Реверси  97 621

•  Графические эффекты  7 344

•  Рисование по маске  6 632

•  Перетаскивание изображений  5 501

•  Canvas Drawing  5 883

•  Рисование Луны  5 611

•  Поворот изображения  5 111

•  Рисование стержней  3 689

•  Paint on Shape  2 915

•  Генератор кроссвордов  3 814

•  Головоломка Paletto  3 063

•  Теорема Монжа об окружностях  3 869

•  Пазл Numbrix  2 547

•  Заборы и коммивояжеры  3 270

•  Игра HIP  2 240

•  Игра Go (Го)  2 171

•  Симулятор лифта  2 552

•  Программа укладки плитки  2 186

•  Генератор лабиринта  2 686

•  Проверка числового ввода  2 331

•  HEX View  2 668

•  Физический маятник  2 306

 
скрыть

Access to table disabled because of previous error - Read failure



Автор: Наталия Елманова
WEB-сайт: http://www.sources.ru

При добавлении новых записей с помощью метода TTable.AppendRecord в индексированную таблицу FoxPro через какое-то время (то есть при одновременном добавлении большого количества записей) возникает ошибка:

"Access to table disabled because of previous error. Read failure. File <имя_файла.cdx>".

Возможно, причина заключается в том, что операции чтения-записи в файл, содержащий таблицу FoxPro, особенно при использовании кэширования, предоставляемого операционной системой, конфликтуют с содержимым индексного файла (это часто происходит при многопользовательской работе). Дело в том, что ранние версии dBase, FoxPro, Clipper работали с неподдерживаемыми индексами, то есть индексные файлы не обновлялись одновременно с таблицей, и для их синхронизации требовалось выполнять специальные операции. Но соответствующие средства разработки, применявшиеся в то время, обычно не поддерживали никаких аналогов транзакций - записи чаще всего вставлялись по одной.

В случае применения старых версий формата FoxPro следует избегать кэширования при выполнении дисковых операций с файловым сервером, содержащим базу данных FoxPro. Кроме того, следует проверить и, если необходимо, изменить в настройках BDE параметры MINBUFSIZE, MAXBUFSIZE, LOCAL SHARE - возможно, проблема заключается в недостаточной величине буферов BDE для кэширования данных или в одновременном доступе к данным приложений, использующих и не использующих BDE.

Еще одним из способов решения этой проблемы (самым радикальным) является замена FoxPro на какую-нибудь из серверных СУБД. Например, InterBase неплохо справляется с одновременным вводом большого количества записей благодаря некоторым специфическим особенностям архитектуры этого сервера.