čtvrtek 27. února 2014

Vývoj databázových aplikací II

Připojení k databázi

Připojení k databázovému stroji je realizováno nevizuální komponentou "FDConnection". Komponenta podporuje připojení k datům již v době návrhu aplikace ("Design Time"), rovněž však může být použita dynamicky a připojení může být s její pomocí vytvořeno až za běhu aplikace ("Run Time"). Z pohledu nakládání s hodnotami parametrů lze rozlišit tři základní přístupy (typy připojení):


FireDAC - Typy připojení

Trvalé připojení

Parametry tohoto typu připojení jsou uloženy v definičním souboru, který může být využíván různými uživateli i aplikacemi. Trvalé připojení lze definovat s využitím nástroje "FireDAC Explorer". FireDAC Explorer je samostatně spustitelný externí program ("FDExplorer.exe"), který nalezneme ve složce určené proměnnou prostředí "BDSBIN". Ve verzi XE5 je to složka "bin" domovského adresáře RAD Studia (při typické instalaci  C:\Programfiles\Embarcadero\RADStudio\12.0).


Nastavení proměnných prostředí naleznete v nastaveních prostředí (nabídka Tools => Options => Environment Options => Environment Variables)

Od verze XE5 je FireDAC zahrnut v hlavní nabídce. Pro spuštění FireDAC Exploreru tedy můžeme kliknout na nabídku "Tools => FireDAC Explorer". V Exploreru lze editovat stávající nebo vytvářet nové definiční soubory. 
Každý definiční soubor může obsahovat parametry pro libovolný počet připojení. Vždy je nejprve třeba určit ovladač (Driver ID) a následně hodnoty jednotlivých parametrů. Ty se samozřejmě liší dle použité databáze. 


Správa definičních souborů ve FireDAC Exploreru

FireDAC Explorer na základě zadaných informací upraví nebo vytvoří nový definiční soubor (textový soubor s příponou .ini), který je uložen na disku a může tak být snadno sdílen.

Nastavení ovladače
Pokud se připojujete k databázím stejného dodavatele, ale v různých verzích, může nastat problém s použitím správných klientských knihoven. Řešením je úprava souboru FDDrivers.ini, nebo změna "VendorLib" pro příslušný "DriverLink".

Příklad 1: Zápis do FDDrivers.ini
[IBXE3]
BaseDriverID=IB
VendorLibWin32=C:\InterBaseXE3\gds32.dll
VendorLibWin64=C:\InterBaseXE3\gds64.dll


Příklad 2: Změna klientské knihovny za běhu
FDConnection1.Close;
FDPhysIBDriverLink1.Release;
FDPhysIBDriverLink1.VendorLib := 'C:\InterBaseXE3\gds32.dll';
FDConnection1.Open;


FireDAC Explorer také nabízí základní funkce pro procházení databázových objektů, zobrazení jejich struktury, zobrazení dat nebo vytváření a spouštění SQL skriptů.

Procházení objektů ve FireDAC Exploreru



Pokud chcete možnost editovat definiční soubory zpřístupnit i koncovým uživatelům aplikace, lze použít nástroj FireDAC Administrátor ("FDAdminstrator.exe"), který je určený k šíření s aplikací. FDAdministrator je omezen na práci s definičními soubory.

Příklad 3: Vytvoření Definičního souboru v kódu aplikace



Delphi



procedure TForm1.ButtonClick(Sender: TObject);
var
CnnParams: TStrings;
CnnDef: IFDStanConnectionDef;

begin
// Nastavení parametrů připojení
CnnParams := TStringList.Create;
CnnParams.Add('Server=WIN-CR0VL03P8IT');
CnnParams.Add('Database=MSDEMODB');
CnnParams.Add('OSAuthent=Yes');

// Vytvoření a pojmenování definičního souboru
FDManager1.ConnectionDefFileName :=
'C:\DEMAXE5\FDConnections\MujDefSoubor.ini';

// Vytvoření a pojmenování definice. Parametry:
// Zvolené jméno pro připojení, ovladač, parametry připojení
FDManager1.AddConnectionDef('SQL_Connection', 'MSSQL', CnnParams);

// Uložení definice
CnnDef := FDManager1.ConnectionDefs.FindConnectionDef ('SQL_Connection');
CnnDef.MarkPersistent();
CnnDef.Apply();

// Připojení k databázi
FDConnection1.ConnectionDefName := 'Test_Connection';
FDConnection1.Connected := True;
end;




C++ Builder


void __fastcall TForm1::ButtonClick(TObject *Sender)
{
TStrings* CnnParams = new TStringList();
IFDStanConnectionDef* CnnDef;

// Nastavení parametrů připojení
CnnParams->Add("Server=WIN-CR0VL03P8IT");
CnnParams->Add("Database=MSDEMODB");
CnnParams->Add("OSAuthent=Yes");

// Vytvoření a pojmenování definičního souboru
FDManager1->ConnectionDefFileName =
"C:\\DEMAXE5\\FDConnections\\MujDefSoubor.ini";

// Uložení definice
FDManager1->AddConnectionDef("Test_Connection", "MSSQL", CnnParams);
CnnDef = FDManager1->
ConnectionDefs->FindConnectionDef("Test_Connection");
CnnDef->MarkPersistent();
CnnDef->Apply();

// Připojení k DB
FDConnection1->ConnectionDefName = "Test_Connection";
FDConnection1->Connected = True;
}



Vyhrazené připojení

Interní připojení umožňuje technologie FireDAC definovat pouze v rámci aplikace. Definiční soubor je vytvořen s využitím komponenty "FDManager" pouze v paměti, ale není uložen na disk pro účely sdílení. Z hlediska kódu je interní připojení identické s připojením trvalým, jen není volána metoda "MarkPersistent". Interní připojení nepodporuje sdružování připojení ("connection pooling").


Dočasné připojení

Pokud je připojení k databázi vytvořené jako dočasné, jsou hodnoty jednotlivých parametrů součástí zdrojového kódu aplikace. Definiční soubor není vytvářen ani v paměti, ani ukládán na disk. Údaje tedy nejsou nikde zveřejněny a nejsou dostupné jiným uživatelům ani aplikacím.

V době návrhu můžeme použít vestavěnou utilitu "Connection editor". Editor spustíme tak, že na formulář umístíme komponentu "FDConnection" a poté na ni klikneme pravým tlačítkem myši.

Vyvolání Connection Editoru


Podle typu databáze, ke které se připojujeme, zvolíme odpovídající ovladač. Následně vyplníme potřebné parametry a nastavení uložíme. Funkčnost připojení lze okamžitě vyzkoušet za pomoci tlačítka "Test".

FireDAC Connection Editor


Další možností je parametry definovat v okně "Object Inspector". Opět je třeba nejprve vybrat ovladač a potom otevřít editor pro vlastnost "Params" a ručně vypsat potřebná nastavení.


Object Explorer


Dočasné připojení je samozřejmě rovněž možné vytvořit programově. Jednotlivé parametry definujeme přímo na úrovni připojení, v našem případě objektu "FDConnection".

Příklad 4: Vytvoření dočasného připojení



Delphi


procedure TForm1.ButtonClick(Sender: TObject);
begin
  FDConnection1.DriverName := 'MSSQL';
  FDConnection1.Params.Add('Server=WIN-CR0VL03P8IT');
  FDConnection1.Params.Add('Database=MSDEMODB');
  FDConnection1.Params.Add('OSAuthent=Yes');
  FDConnection1.Connected := True;
end;




C++ Builder


void __fastcall TForm1::ButtonClick(TObject *Sender)
{
  FDConnection1->DriverName = "MSSQL";
  FDConnection1->Params->Add("Server=WIN-CR0VL03P8IT");
  FDConnection1->Params->Add("Database=MSDEMODB");
  FDConnection1->Params->Add("OSAuthent=Yes");
  FDConnection1->Connected = True;
}


Connection Editor je možné zpřístupnit i uživatelům aplikace. Stačí do sekce "uses" přidat unitu "ConnEdit" a následně z kódu otevřít v ní definovaný dialog.

Příklad 5: Otevření Editoru připojení z kódu



Delphi


uses FireDAC.VCLUI.ConnEdit;

procedure TForm1.ButtonClick(Sender: TObject);
begin
  if TfrmFDGUIxFormsConnEdit.Execute(FDConnection1, '') then
    FDConnection1.Connected := True
end;




C++ Builder


#include

void __fastcall TForm1::ButtonClick(TObject *Sender)
{
  TfrmFDGUIxFormsConnEdit *frmFDGUIxFormsConnEdit1;
  if (frmFDGUIxFormsConnEdit1->Execute(FDConnection1, "")) {
    FDConnection1->Connected = True;
}
}



sobota 8. února 2014

Vývoj databázových aplikací I

Připojení k databázím

Vývojové nástroje Delphi a C++ Builder byly od počátku navrženy pro tvorbu podnikových aplikací, ke kterým neodmyslitelně patří i možnost spolupráce s databázovými stroji. Tak, jak se rozšiřovala nabídka databázových strojů, a měnily se požadavky uživatelů, byla do Delphi i C++ Builderu postupně implementována řada technologií pro přístup k relačním databázím.


Přínos DB komponent

S databázovým serverem by bylo samozřejmě možné komunikovat i přímo bez DB komponent. Jednotlivé databázové servery se však liší jak nabízenými funkcemi, tak i rozhraním, prostřednictvím kterého je možné tyto funkce volat. Server je většinou provozován na jiném stroji, často i na odlišném operačním systému. Dodavatelé tak spolu s DB serverem šíří zpravidla také klientské knihovny pro jednotlivé operační systémy a jejich verze. Klientské knihovny poskytují rozhraní (API) pro vývojáře aplikačního software. I tato rozhraní jsou však ještě příliš specifická. Vývojové nástroje společnosti Embarcadero proto nabízí DB komponenty a ovladače, které vývojáře odstíní od konkrétní implementace a umožňují jim vytvářet snadno přenositelné aplikace, provozovatelné s databázovými stroji různých dodavatelů.


FireDAC

FireDAC je souborem knihoven pro práci s daty získaný v únoru 2013 v rámci akvizice od ruské společnosti DA-Soft. Hlavními přínosy je možnost nasazení na různých platformách včetně mobilních zařízení, rychlost a zpřístupnění specifických funkcí jednotlivých databázových strojů. Spolu s vývojovými nástroji společnosti Embarcadero jsou stále dodávány i další technologie pro přístup k datům (především z důvodu zpětné kompatibility), FireDAC je však v tomto směru jednoznačně "vlajkovou lodí" a pro nové projekty by měl být preferovanou volbou.

FireDAC - Databázový "Hello World"

Než se podrobněji podíváme na jednotlivé komponenty, ukážeme si použití FireDAC komponent na nejjednodušším možném příkladu. Připojíme se k databázi, formulujeme SQL dotaz a zobrazíme získaná data. Na formulář umístíme následující komponenty:

FDConnection - nastavuje parametry připojení k databázi
FDQuery - slouží k definování SQL dotazu
DataSource - zprostředkovává přístup k datové sadě
DBGrid - datová mřížka pro zobrazení dat
DBNavigator - navigační lišta
FDGUIxWaitCursor - multiplatformní "přesýpací hodiny"
FDPhysIBDriverLink (databázový ovladač pro InterBase)



Za pomoci Inspektora objektů nastavíme základní vlastnosti pro jednotlivé komponenty:



Nastavení FDConnection.Params:
Server=localhost
User_Name=SYSDBA
Password=masterkey
CharacterSet=WIN1250
Database=C:\IBData\IBDEMODB.IB
DriverID=IB

Nastavení FDQuery.SQL:
select osoba_id, prijmeni, jmeno from osoba;


Konfigurace je plně totožná s BDE, což usnadňuje případnou migraci starších databázových aplikací.


Použití komponenty TADGUIxWaitCursor nebo přidání unity uADCompGUIx do uses je povinné pro každý projekt využívající technologii FireDAC. V případě, že projekt obsluhu kurzoru neobsahuje, skončí překlad aplikace selháním a je zobrazeno chybové hlášení.




Přiřazení ovladače je povinné pro všechny projekty využívající technologii FireDAC. Pokud není ovladač k aplikaci ani jedním z uvedených způsobů připojen, sestavování aplikace selže a zobrazí se chybové hlášení.




Porovnání FireDAC s ostatními knihovnami

BDE - Původní technologie společnosti Borland pro připojení k databázím. Od roku 2002 již není dále rozvíjena. Neobsahuje tak např. podporu unicode, 64-bitových Windows nebo platformy FireMonkey. BDE je dodáván s ohledem na údržbu starších aplikací, jeho použití v nových projektech se důrazně nedoporučuje.

dbGo (ADO) - Sada komponent zajišťujících přístup k databázím prostřednictvím technologie ActiveX Data Objects (ADO) společnosti Microsoft. Použitelnost je omezena pouze na operační systémy MS Windows.

InterBase Express (IBX) - specializované komponenty pro databázový stroj Interbase. Kromě připojení k DB a zajištění přístupu k datům obsahuje i podporu čiností spojených se správou serveru jako je např. zálohování a obnova dat.

dbExpress - Nástupce BDE uvedený cca v roce 2000 (Delphi 6). Od odstatních typů připojení se odlišuje použitím jednosměrných (unidirectional) datových sad. Výsledky dotazů nejsou automaticky ukládány do vyrovnávací paměti. Pro aktualizaci databáze je třeba použít komponentu "DataSetProvider" a zajistit ošetření případných konfliktů.



Vývojové nástroje Delphi, C++ Builder nebo RAD Studio jsou v současnosti dostupné v mnoha edicích. Jednou z oblastí, v kterých se dodávané edice liší je právě podpora vývoje databázových aplikací. Následující tabulka ukazuje, které technologie jsou v jednotlivých edicích dostupné:




Pro edice Professional je k dispozici balíček "FireDAC Client/Server Add-On Pack", který rozšiřuje možnosti připojení o přístup k databázím Oracle, SQL Server, InterBase, DB2, Firebird, SQLite, MySQL, PostgreSQL, SQL Anywhere, Advantage DB, Access, Informix, DataSnap a dalším.