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

•  DeLiKaTeS Tetris (Тетрис)  1 563

•  TDictionary Custom Sort  4 217

•  Fast Watermark Sources  3 891

•  3D Designer  6 010

•  Sik Screen Capture  4 160

•  Patch Maker  4 698

•  Айболит (remote control)  4 611

•  ListBox Drag & Drop  3 758

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

•  Графические эффекты  4 948

•  Рисование по маске  3 965

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

•  Canvas Drawing  3 638

•  Рисование Луны  3 431

•  Поворот изображения  2 934

•  Рисование стержней  2 600

•  Paint on Shape  1 990

•  Генератор кроссвордов  2 756

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

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

•  Пазл Numbrix  1 954

•  Заборы и коммивояжеры  2 529

•  Игра HIP  1 569

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

•  Симулятор лифта  1 782

•  Программа укладки плитки  1 529

•  Генератор лабиринта  1 892

•  Проверка числового ввода  1 645

•  HEX View  1 829

•  Физический маятник  1 662

 
скрыть


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

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



Delphi Sources

Динамически создаваемые псевдонимы



Использование псевдонима для доступа к базе данных обеспечивает независимость программы от размещения данных в системе, позволяет размещать программу работы с данными и базу данных на разных дисках компьютера, в том числе и на сетевом. Вместе с тем, для простых баз данных типичным решением является размещение базы данных в отдельном подкаталоге того каталога, в котором находится программа работы с базой данных. Таким образом, программа работы с базой данных всегда "знает", где находятся данные. При таком подходе можно отказаться от создания псевдонима при помощи BDE Administrator и возложить задачу создания псевдонима на программу работы с базой данных. Причем, псевдоним будет создаваться автоматически во время запуска программы и уничтожаться во время завершения ее работы. Очевидно, что такой подход облегчает администрирование базы данных.

В качестве иллюстрации сказанного в листинге приведен вариант программы работы с базой данных "Школа", которая для доступа к базе данных использует динамически создаваемый псевдоним.

unit school3_;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms,
  Dialogs, Grids, DBGrids, Db, DBTables, ExtCtrls, DBCtrls, StdCtrls;

type
  TForm1 = class(TForm)
    Table1: TTable; // таблица (вся база данных)
    Query1: TQuery; // запрос (записи БД, удовлетворяющие критерию выбора)
    DataSource1: TDataSource; // источник данных - таблица или запрос
    DBGrid1: TDBGrid; // таблица для отображения БД или результата выполнения запроса
    DBNavigator1: TDBNavigator;
    DBText1: TDBText;
    Button1: TButton; // кнопка запрос
    Button2: TButton; // кнопка Все записи
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
    procedure FormActivate(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.DFM}

// щелчок на кнопке Запрос
procedure TForm1.Button1Click(Sender: TObject);
var
  fam: string[30];
begin
  fam := InputBox('Выборка информации из БД',
    'Укажите фамилию и щелкните на OK.', '');
  if fam <> '' // пользователь ввел фамилию
    then
  begin
    with form1.Query1 do begin
      Close; // закрыть файл-результат выполнения предыдущего запроса
      SQL.Clear; // удалить текст предыдущего запроса
      // записываем новый запрос в свойство SQL
      SQL.Add('SELECT Fam, Name, Class');
      SQL.Add('FROM ":Школа:school.db"');
      SQL.Add('WHERE');
      SQL.Add('(Fam = "' + fam + '")');
      SQL.Add('ORDER BY Name, Fam');
      Open; // активизируем выполнение запроса
    end;

    if Query1.RecordCount <> 0 then
      DataSource1.DataSet := Query1 // отобразить рез-т выполнения запроса
    else begin
      ShowMessage('В БД нет записей, удовлетворяющих критерию запроса.');
      DataSource1.DataSet := Table1;
    end;
  end;
end;

// щелчок на кнопке Все записи
procedure TForm1.Button2Click(Sender: TObject);
begin
  DataSource1.DataSet := Table1; // источник данных - таблица
end;

// активизация формы
procedure TForm1.FormActivate(Sender: TObject);
begin
  with Session do
  begin
    ConfigMode := cmSession;
    try
      { Если файл данных находиться в том же каталоге,
      что и выполняемый файл программы, то в программе
      путь к файлу данных может быть получен из командной
      строки при помощи функции ExtractFilePath(ParamStr(0)).
      В приведенном примере файл данных находиться в подкаталоге
      DATA каталога программы. }

      // создадим временный псевдоним для базы данны
      AddStandardAlias('Школа',
        ExtractFilePath(ParamStr(0)) + 'DATA\',
        'PARADOX');
      Table1.Active := True; // откроем базу данных
    finally
      ConfigMode := cmAll;
    end;
  end;
end;

end.

В рассматриваемом варианте программы предполагается, что база данных содержится в подкаталоге DATA того каталога, в котором находится выполняемый файл программы. Создает псевдоним процедура TForm1.FormActivate. Непосредственное создание псевдонима выполняет процедура AddstandardAlias, которой в качестве параметра передается имя псевдонима и соответствующее ему имя каталога. Так как во время разработки программы нельзя знать, в каком каталоге будет размещена программа работы с базой данных и, следовательно, подкаталог базы данных -DATA, имя каталога определяется во время работы программы путем обращения к функциям ParamStr(0) и ExtractFilePatch. Значение первой -полное имя выполняемого файла программы, второй — путь к этому файлу. Таким образом, процедуре AddstandardAiias передается полное имя каталога базы данных.








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

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