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

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

•  TDictionary Custom Sort  6 725

•  Fast Watermark Sources  6 508

•  3D Designer  9 446

•  Sik Screen Capture  6 839

•  Patch Maker  7 289

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

•  ListBox Drag & Drop  6 094

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

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

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

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

•  Canvas Drawing  5 942

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

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

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

•  Paint on Shape  2 966

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

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

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

•  Пазл Numbrix  2 578

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

•  Игра HIP  2 313

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

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

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

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

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

•  HEX View  2 698

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

 
скрыть

Пакование таблиц 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;





Похожие по теме исходники

Создание таблиц в Paradox

Таблица совместимости продуктов питания