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

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

•  TDictionary Custom Sort  6 713

•  Fast Watermark Sources  6 490

•  3D Designer  9 428

•  Sik Screen Capture  6 827

•  Patch Maker  7 268

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

•  ListBox Drag & Drop  6 075

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

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

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

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

•  Canvas Drawing  5 935

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

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

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

•  Paint on Shape  2 956

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

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

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

•  Пазл Numbrix  2 569

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

•  Игра HIP  2 305

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

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

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

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

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

•  HEX View  2 693

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

 
скрыть

  Форум  

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

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



Delphi Sources

Получение физического пути к таблице



Автор: Xavier Pacheco

Если ссылка на таблицу получена через псевдоним, получить физический путь к ней не так просто. Для получения этого пути необходимо использовать функцию BDE DbiGetDatabaseDesc. Данной функции в качестве параметров передаются имя псевдонима и указатель на структуру DBDesc. Структура DBDesc будет заполнена информацией, относящейся к этому псевдониму. Определение структуры:


pDBDesc = ^DBDesc;
DBDesc = packed record        { Описание данной базы данных }
szName          : DBINAME;    { Логическое имя (или псевдоним) }
szText          : DBINAME;    { Описательный текст }
szPhyName       : DBIPATH;    { Физическое имя/путь }
szDbType        : DBINAME;    { Тип базы данных }
end;

Физическое имя/путь будет содержаться в поле szPhyName структуры DBDesc.

Возможные значения, возвращаемые функцией DBIGetDatbaseDesc:

DBIERR_NONE             Описание базы данных для pszName было успешно извлечено.
DBIERR_OBJNOTFOUND      База данных, указанная в pszName, не была обнаружена.

Приведенный ниже пример кода показывает как можно получить физический путь для компонента TTable, использующего псевдоним DBDemos:


var
  vDBDesc: DBDesc;
  DirTable: String;
begin
  Check(DbiGetDatabaseDesc(PChar(Table1.DatabaseName), @vDBDesc));
  DirTable := Format('%s\%s', [vDBDesc.szPhyName, Table1.TableName]);
  ShowMessage(DirTable);
end;





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

A Star (нахождение кратчайшего пути)

Нахождение кратчайшего пути

Дейкстра: поиск кратчайшего пути