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

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

•  TDictionary Custom Sort  6 815

•  Fast Watermark Sources  6 598

•  3D Designer  9 560

•  Sik Screen Capture  6 936

•  Patch Maker  7 385

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

•  ListBox Drag & Drop  6 188

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

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

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

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

•  Canvas Drawing  6 024

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

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

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

•  Paint on Shape  3 016

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

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

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

•  Пазл Numbrix  2 631

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

•  Игра HIP  2 359

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

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

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

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

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

•  HEX View  2 729

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

 
скрыть

  Форум  

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 (нахождение кратчайшего пути)

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

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