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

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

•  TDictionary Custom Sort  6 827

•  Fast Watermark Sources  6 606

•  3D Designer  9 572

•  Sik Screen Capture  6 946

•  Patch Maker  7 393

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

•  ListBox Drag & Drop  6 200

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

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

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

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

•  Canvas Drawing  6 032

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

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

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

•  Paint on Shape  3 020

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

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

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

•  Пазл Numbrix  2 636

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

•  Игра HIP  2 361

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

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

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

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

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

•  HEX View  2 733

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

 
скрыть

  Форум  

Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Пакование таблиц dBASE 2



Упаковка таблиц dBASE требует вызова BDE функции DbiPackTable. Пример ее использования показан ниже, включая проверку на ошибки. Чтобы воспользоваться функцией DbiPackTable, вызывающий модуль должен в своей секции uses иметь модули-обертки BDE DbiTypes, DbiErrs и DbiProcs.

При неудачном вызове DbiPackTable, сообщение об ошибке не генерится. Для того, чтобы понять как функция сработала, вам необходимо проверить возвращаемое ею значение. В случае успешного выполнения возвращаемое значение равно DBIERR_NONE. Любое другое значение указывает на ошибку, а с помощью него можно определить саму ошибку, ее причину, и наметить действия, необходимые для ее устранения.

Вот сам пример:


procedure TForm1.Button1Click(Sender: TObject);
var
  Error: DbiResult;
  ErrorMsg: string;
  Special: DBIMSG;
begin
  table1.Active := False;
  try
    Table1.Exclusive := True;
    Table1.Active := True;
    Error := DbiPackTable(Table1.DBHandle, Table1.Handle, nil, szdBASE, True);
    Table1.Active := False;
    Table1.Exclusive := False;
  finally
    Table1.Active := True;
  end;
  case Error of
    DBIERR_NONE:
      ErrorMsg := 'Успешно';
    DBIERR_INVALIDPARAM:
      ErrorMsg := 'Указанное имя таблицы или указатель на имя таблицы ' +
        'равен NULL';
    DBIERR_INVALIDHNDL:
      ErrorMsg := 'Указанный дескриптор базы данных или курсора ' +
        'неверен или равен NULL';
    DBIERR_NOSUCHTABLE:
      ErrorMsg := 'Таблица с таким именем не существует';
    DBIERR_UNKNOWNTBLTYPE:
      ErrorMsg := 'Неизвестный тип таблицы';
    DBIERR_NEEDEXCLACCESS:
      ErrorMsg := 'Таблица открыта не в эксклюзивном режиме';
  else
    DbiGetErrorString(Error, Special);
    ErrorMsg := '[' + IntToStr(Error) + ']: ' + Special;
  end;
  MessageDlg(ErrorMsg, mtWarning, [mbOk], 0);
end;