Карта сайта Kansoftware
НОВОСТИУСЛУГИРЕШЕНИЯКОНТАКТЫ
KANSoftWare

Упаковка таблиц Paradox и dBase

Delphi , Базы данных , Paradox



Автор: Александр
WEB-сайт: http://delphibase.endimus.com

{ **** UBPFD *********** by delphibase.endimus.com ****
>> Упаковка таблиц Paradox & dBase

Процедура упаковки таблиц Paradox & dBase.
В процедуру передается TTable c любым состоянием свойства Active.
Состояние Active после выполнения процедуры остается предыдущим.
Процедура предусматривает отключение всех визуальных DbControls,
с последующим их подключением.

Зависимости: Bde, Db, DbTables
Автор:       Александр, dbwork@kor.kes.ru, Кореновск
Copyright:   Из исходного кода Database Workshop 4.12 (c)2002 Degisy Software
Дата:        23 мая 2002 г.
***************************************************** }

procedure Bde_PackTable(DataSet: TDataSet);
var
  hDb: hDBIDb;
  Tbl: TTable;
  Props: CURProps;
  CrDesc: CRTblDesc;
  Save: Boolean;
begin
  if (DataSet is TTable) then
  begin
    Tbl := TTable(DataSet);
    Save := Tbl.Active;
    Tbl.Active := True;
    try
      Check(DbiGetCursorProps(Tbl.Handle, Props));
      if (Props.szTableType = szPARADOX) then
      begin
        FillChar(CrDesc, SizeOf(CRTblDesc), 0);
        StrCopy(CrDesc.szTblName, Props.szName);
        StrCopy(CrDesc.szTblType, Props.szTableType);
        CrDesc.bPack := True;
        Check(DbiGetObjFromObj(hDBIObj(Tbl.Handle), objDATABASE, hDBIObj(hDb)));
        Tbl.DisableControls;
        Tbl.Active := False;
        Check(DbiDoRestructure(hDb, 1, @CrDesc, nil, nil, nil, False));
      end
      else if (Props.szTableType = szDBASE) then
      begin
        Tbl.Active := True;
        Check(DbiPackTable(Tbl.DBHandle, Tbl.Handle, nil, szDBASE, True));
      end;
    finally
      Tbl.Active := Save;
      Tbl.EnableControls;
    end;
  end;
end;

Пример использования:

Bde_PackTable(Table1); 

Программный код на Delphi для упаковки таблиц в базах данных Paradox и dBase с помощью BDE (Borland Database Engine). Процедура принимает объект TDataSet в качестве параметра, представляющего таблицу в базе данных.

Вот шаг за шагом, что происходит в коде:

  1. Он проверяет, является ли входной дата-сет TTable объектом. Если это так, то продолжается процесс упаковки.
  2. Он сохраняет текущее состояние свойства Active таблицы и устанавливает его в True. Это обеспечивает открытие таблицы в режиме чтения-записи для операции упаковки.
  3. Он получает свойства курсора таблицы с помощью DbiGetCursorProps.
  4. Если тип таблицы Paradox, он заполняет структуру CRTblDesc информацией о таблице и устанавливает свойство bPack в True. Затем он вызывает DbiDoRestructure, чтобы выполнить операцию упаковки.
  5. Если тип таблицы dBase, он вызывает функцию DbiParam, чтобы упаковать таблицу.
  6. Наконец, он восстанавливает оригинальное состояние свойства Active таблицы и включает ее контроли.

Код также включает в себя обработку ошибок с помощью операторов Check, чтобы обеспечить ловлю и обработку любых ошибок, возникших во время операции упаковки.

Возможный альтернативный способ решения:

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

Пример кода:

procedure PackTable(Dataset: TDataSet);
var
  Stream: TStream;
begin
  if Dataset is TTable then
  begin
    Tbl := TTable(Dataset);
    Tbl.DisableControls;
    try
      Tbl.SaveToStream(Stream);
    finally
      Tbl.EnableControls;
    end;
  end;
end;

В этом коде используется метод SaveToStream компонента TTable, чтобы сохранить данные таблицы в потоке. Это более простое и эффективное решение, чем использование BDE.

Вы можете вызвать эту процедуру, например:

PackTable(Table1);

Обратите внимание, что это процедура предполагает, что дата-сет является объектом TTable и не проверяет другие типы дата-сетов. Вам может потребоваться модификация кода, если вы хотите поддерживать другие типы дата-сетов.

Процедура упаковки таблиц Paradox и dBase, которая отключает все визуальные DbControls, выполняет упаковку таблицы и последовательно подключает и отключает контролы.


Комментарии и вопросы

Получайте свежие новости и обновления по Object Pascal, Delphi и Lazarus прямо в свой смартфон. Подпишитесь на наш Telegram-канал delphi_kansoftware и будьте в курсе последних тенденций в разработке под Linux, Windows, Android и iOS




Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.


:: Главная :: Paradox ::


реклама


©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007
Top.Mail.Ru

Время компиляции файла: 2024-12-22 20:14:06
2025-06-16 16:05:56/0.0017590522766113/0