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

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

•  TDictionary Custom Sort  6 349

•  Fast Watermark Sources  6 138

•  3D Designer  9 075

•  Sik Screen Capture  6 461

•  Patch Maker  6 877

•  Айболит (remote control)  6 859

•  ListBox Drag & Drop  5 734

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

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

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

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

•  Canvas Drawing  5 622

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

•  Поворот изображения  4 871

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

•  Paint on Shape  2 714

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

•  Головоломка Paletto  2 884

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

•  Пазл Numbrix  2 424

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

•  Игра HIP  2 067

•  Игра Go (Го)  1 992

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

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

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

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

•  HEX View  2 527

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

 
скрыть

  Форум  

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

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



Delphi Sources

Перемещение таблиц



Здесь я привожу примеры программ, которые я использую для копирования и удаления таблиц. Необходимые для работы модули: DB, DBTables, DbiProcs,DbiErrs, и DbiTypes. Вам всего лишь необходимо указать каталог расположения, исходное имя таблицы, каталог назначения и имя таблицы, куда будет скопирована исходная таблица и BDE скопирует таблицу целиком со всеми индексами. Процедура удаления в качестве входных параметров использует каталог расположения и имя таблицы, при этом BDE удаляет как саму таблицу, так и все файлы, связанные с ней (индексы и т.п.). Для тестирования данные процедуры были помещены в новое приложение и мне пришлось их немного отредактировать, чтобы удалить некоторые зависимости, которые были связаны с главной формой приложения. Теперь процедуры являются полностью автономными и могут быть помещены в отдельный модуль. (Не забудьте включить его в список используемых модулей). Пользуйтесь на здоровье!


procedure TConvertForm.CopyTable(FromDir, SrcTblName, ToDir, DestTblName:
  string);
var
  DBHandle: HDBIDB;
  ResultCode: DBIResult;
  Src, Dest, Err: array[0..255] of Char;
  SrcTbl, DestTbl: TTable;
begin
  SrcTbl := TTable.Create(Application);
  DestTbl := TTable.Create(Application);
  try
    SrcTbl.DatabaseName := FromDir;
    SrcTbl.TableName := SrcTblName;
    SrcTbl.Open;
    DBHandle := SrcTbl.DBHandle;
    SrcTbl.Close;
    ResultCode := DbiCopyTable(DBHandle, false,
      StrPCopy(Src, FromDir + '\' + SrcTblName), nil,
      StrPCopy(Dest, ToDir + '\' + DestTblName));
    if (ResultCode <> DBIERR_NONE) then
    begin
      DbiGetErrorString(ResultCode, Err);
      raise EDatabaseError.Create('При копировании ' +
        FromDir + '\' + SrcTblName + ' в ' +
        ToDir + '\' + DestTblName + ' ,'
        + 'BDE сгенерировал ошибку '''
        + StrPas(Err) + '''');
    end;
  finally
    SrcTbl.Free;
    DestTbl.Free;
  end;
end;

procedure TConvertForm.DeleteTable(Dir, TblName: string);
var
  DBHandle: HDBIDB;
  ResultCode: DBIResult;
  tbl, Err: array[0..255] of Char;
  SrcTbl, DestTbl: TTable;
  SrcTbl := TTable.Create(Application);
begin
  try
    SrcTbl.DatabaseName := Dir;
    SrcTbl.TableName := TblName;
    SrcTbl.Open;
    DBHandle := SrcTbl.DBHandle;
    SrcTbl.Close;
    ResultCode := DbiDeleteTable(DBHandle,
      StrPCopy(Tbl, Dir + '\' + TblName), nil);
    if (ResultCode <> DBIERR_NONE) then
    begin
      DbiGetErrorString(ResultCode, Err);
      raise EDatabaseError.Create('Удаляя ' +
        Dir + '\' + TblName + ', BDE ' +
        'сгенерировал ошибку '''
        + StrPas(Err) + '''');
    end;
  finally
    SrcTbl.Free;
  end;
end;





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

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

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




Copyright © 2004-2025 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте