Difference between revisions of "Databases/de"

From Lazarus wiki
Jump to navigationJump to search
m
 
(35 intermediate revisions by 10 users not shown)
Line 1: Line 1:
 
{{Databases}}
 
{{Databases}}
 +
 +
Diese Seite ist noch unfertig ...
 +
 +
{{Database Programming/de}}
  
 
== Einleitung ==
 
== Einleitung ==
  
Wie bei anderen Entwicklungssystemen auch spielt die Zusammenarbeit mit verschiedenen Datenbanken bei Lazarus eine nicht unbedeutende Rolle. Während ein Teil der Funktionalität schon mit FPC zur Verfügung steht, kommen andere Teile (insbesondere die visuellen Komponenten) erst mit Lazarus selbst hinzu. Die bei Lazarus enthaltenen Komponenten decken schon ein gewisses Spektrum an Datenbanken ab. Da aber immer Verbesserungsbedarf besteht und es auch exotischere Datenbanken gibt, existieren externe Komponenten / Bibliotheken, welche die Möglichkeiten von Lazarus erweitern.  
+
Wie bei anderen Entwicklungssystemen auch spielt die Zusammenarbeit mit verschiedenen Datenbanken bei Lazarus eine bedeutende Rolle. Während ein Teil der Funktionalität schon mit FPC zur Verfügung steht, kommen andere Teile (insbesondere die visuellen Komponenten) erst mit Lazarus selbst hinzu. Die bei Lazarus enthaltenen Komponenten decken schon ein gewisses Spektrum an Datenbanken ab. Da aber immer Verbesserungsbedarf besteht und es auch exotischere Datenbanken gibt, existieren externe Komponenten / Bibliotheken, die die Möglichkeiten von Lazarus erweitern.  
  
Diese Seite stellt einen Einstieg für das Thema 'Lazarus und Datenbanken' dar. Die folgende Tabelle bietet einen Überblick über die unterstützten Datenbanken. Da sie noch auf dem Stand von FPC 1.9.7 basiert, sollte sie schnellstens auf den aktuellen Stand gebracht werden. Ein Hinweis noch an alle Experimentierfreudigen: Installieren sie nur die Datenbank-Komponenten, deren Client-Bibliotheken (falls diese erforderlich sind) auf ihrem Computer installiert sind. Sonst kann es passieren, daß Lazarus den Start mit einer Fehlermeldung (wegen fehlender Dateien) verweigert. Da sie somit keine Möglichkeit mehr haben, die Komponenten zu deinstallieren, ist eine Neuinstallation von Lazarus erforderlich.
+
Diese Seite stellt einen Einstieg für das Thema 'Lazarus und Datenbanken' dar. Die folgende Tabelle bietet einen Überblick über die unterstützten Datenbanken. Da sie noch auf dem Stand von FPC 1.9.7 basiert, sollte sie schnellstens auf den aktuellen Stand gebracht werden. Ein Hinweis noch an alle Experimentierfreudigen: Installieren sie nur die Datenbank-Komponenten, deren Client-Bibliotheken (falls diese erforderlich sind) auf ihrem Computer installiert sind. Sonst kann es passieren, dass Lazarus den Start mit einer Fehlermeldung (wegen fehlender Dateien) verweigert. Da sie somit keine Möglichkeit mehr haben, die Komponenten zu deinstallieren, ist eine Neuinstallation von Lazarus erforderlich.
  
 
=== Tabelle 1 ===
 
=== Tabelle 1 ===
 
+
{| class="wikitable sortable" BORDER="1" CELLSPACING="0"
{| BORDER="1" CELLSPACING="0"
 
 
!STYLE="background:#ffdead;"|'''Datenbank'''
 
!STYLE="background:#ffdead;"|'''Datenbank'''
 
!STYLE="background:#ffdead;"|'''Package Name'''
 
!STYLE="background:#ffdead;"|'''Package Name'''
!STYLE="background:#ffdead;"|'''Need client lib?'''
+
!STYLE="background:#ffdead;"|'''Benötigt eine <br>Client Bibliothek?'''
 
!STYLE="background:#ffdead;"|'''Benötigt Server?'''
 
!STYLE="background:#ffdead;"|'''Benötigt Server?'''
 
!STYLE="background:#ffdead;"|'''Unterstützte Versionen'''
 
!STYLE="background:#ffdead;"|'''Unterstützte Versionen'''
 
!STYLE="background:#ffdead;"|'''Unterstützte Plattformen'''
 
!STYLE="background:#ffdead;"|'''Unterstützte Plattformen'''
 
|----
 
|----
|'''Textdateien'''||sdf||Nein||Nein|| - || Alle
+
|'''Textdateien'''||SDFLaz||Nein||Nein|| - || Alle
 +
|----
 +
|'''Im Speicher'''||MemDSLaz||Nein||Nein|| - || Alle
 
|----
 
|----
|'''Im Speicher'''||memds||Nein||Nein|| - || Alle
+
|'''DBase'''||[[Lazarus_Tdbf_Tutorial/de | DBFLaz]]||Nein||Nein|| III+, IV, VII || Alle
 
|----
 
|----
|'''DBase'''||[[Lazarus_Tdbf_Tutorial/de | tDbf]]||Nein||Nein|| III+, IV, VII || Alle
+
|'''FoxPro'''||[[Lazarus_Tdbf_Tutorial/de | DBFLaz]]||Nein||Nein|| 2.0, 2.5, 3.0 (nicht vollständig) || Alle
 
|----
 
|----
|'''FoxPro'''||[[Lazarus_Tdbf_Tutorial/de | tDbf]]||Nein||Nein|| - || Alle
+
|'''Paradox'''||[[TParadoxDataSet | TParadoxDataSet]]||Nein||Nein|| bis zu Version 7 (und höher ??) || Alle
 
|----
 
|----
|[http://www.sqlite.org/ '''SQLite''']||SQLite||Ja||Nein|| - || -
+
|[http://www.sqlite.org/ '''SQLite''']||SQLite||Ja||Nein|| 2.x, 3.x || Alle
 
|----
 
|----
|[http://www.mysql.com/ '''MySQL''']||[[MySQLDatabases/de | MySQL]]||Ja||Ja|| 3 - 4.0 || i386: Linux, Win32
+
|[http://www.mysql.com/ '''MySQL''']||[[MySQLDatabases/de | SQLdb]]||Ja||Ja|| 3 - 5.5 || i386: Linux, Win32
 
|----
 
|----
|[http://www.firebirdsql.org/ '''Firebird''']||IBase||Ja||Ja||1 - 1.5|| i386: Linux, Win32
+
|[http://www.firebirdsql.org/ '''Firebird''']||IBase||Ja||Depends<sup>1)</sup>||1 - 2.5|| i386: Linux, Win32
 
|----
 
|----
|[http://www.postgresql.org/ '''PostgreSQL''']||postgres||Ja||Ja|| 6.6 - 8 || i386: Linux, Win32
+
|[http://www.postgresql.org/ '''PostgreSQL''']||SQLdb||Ja||Ja|| 6.6 - 8 || i386: Linux, Win32
 
|----
 
|----
|'''ODBC'''||ODBC||Ja||Depends|| - || i386: Win32
+
|'''ODBC'''||[[ODBCConn|SQLdb]]||Ja||Depends|| 3.x <sup>2)</sup> || i386: Linux, Win32
 
|----
 
|----
|[http://www.borland.com/us/products/interbase/index.html '''Interbase''']||IBase||Ja||Ja||4 - 6|| i386: Linux, Win32
+
|[http://www.embarcadero.com/products/interbase-smp '''Interbase''']||IBase||Ja||Ja||4 - 6|| i386: Linux, Win32
 
|----
 
|----
|[http://www.oracle.com/ '''Oracle''']||Oracle||Ja||Ja|| - || -  
+
|[http://www.oracle.com/ '''Oracle''']||SQLdb||Ja||Ja|| - || -  
 +
|----
 +
|[http://www.advantagedatabase.com/ '''Advantage''']||TAdsDataSet||Ja||Nein||10.1 und höher|| i386: Linux, Win32
 
|}
 
|}
 +
 +
<sup>1)</sup> Sie können eine eingebettete Version von Firebird zumindest unter Windows benutzen (möglicherweise unter Linux/OSX mit einigen Verrenkungen), oder Sie nehmen eine Server-Version unter Windows/Unix/OSX/FreeBSD/anderen von Firebird unterstützen Plattformen
 +
 +
<sup>2)</sup> Diese Versionsnummer bezieht sich auf den ODBC Standard, nicht auf die Versionsnummer eines Treibers oder Treibermanagers. Es gibt ODBC 3.x Treiber für die meisten DBMS.
  
 
== Weitere Informationen zu Lazarus und Datenbanken ==
 
== Weitere Informationen zu Lazarus und Datenbanken ==
Line 45: Line 56:
 
* Tutorial: [[Lazarus Database Tutorial/de|Lazarus Database Tutorial]]
 
* Tutorial: [[Lazarus Database Tutorial/de|Lazarus Database Tutorial]]
 
* MySQL: [[MySQLDatabases/de|MySQLDatabases]]
 
* MySQL: [[MySQLDatabases/de|MySQLDatabases]]
* Firebird: [[Firebird in action]]
+
* Firebird: [[Firebird]]
 +
* ODBC: [[ODBCConn]]
  
 
== Unterschiede zu Delphi ==
 
== Unterschiede zu Delphi ==
  
Der vielleicht wichtigste Vorteil von Lazarus gegenüber Delphi ist die Plattformunabhängigkeit. Das bedeutet auf der anderen Seite, daß es für die Windows-spezifischen Teile bei Delphi (z.B. die BDE) keine direkten Entsprechungen bei Lazarus gibt. Gleiches gilt für die meisten Reporting-Werkzeuge. Bei der Konvertierung eines Delphiprogramms nach Lazarus sollte man auf die verschiedenen Dateisysteme achten, wenn das Programm auf allen von Lazarus unterstützten Plattformen laufen soll. Als Beispiel möchte ich nur die unterschiedlichen Trennzeichen im Pfadnamen ( \ bzw. / ) nennen.
+
Der vielleicht wichtigste Vorteil von Lazarus gegenüber Delphi ist die Plattformunabhängigkeit. Das bedeutet auf der anderen Seite, dass es für die Windows-spezifischen Teile bei Delphi (z.B. die BDE) keine direkten Entsprechungen bei Lazarus gibt. Gleiches gilt für die meisten Reporting-Werkzeuge. Bei der Konvertierung eines Delphiprogramms nach Lazarus sollte man auf die verschiedenen Dateisysteme achten, wenn das Programm auf allen von Lazarus unterstützten Plattformen laufen soll. Als Beispiel möchte ich nur die unterschiedlichen Trennzeichen im Pfadnamen ( \ bzw. / ) nennen.
  
 
== In Lazarus enthaltene Datenbank-Packages ==
 
== In Lazarus enthaltene Datenbank-Packages ==
  
 
=== sqldblaz.lpk ===
 
=== sqldblaz.lpk ===
Dieses Package bietet Zugriff auf verschiedene Datenbanken (z.B. MySQL oder Interbase/Firebird). Das Package wird standardmäßig mit Lazarus installiert. Die Komponenten (TSQLQuery, TSQLTransaction, TIBConnection, TODBCConnection, TMySQLConnection, TPQConnection) befinden sich auf der 'SQLdb' Seite in der Komponentenpalette.
+
Dieses Package bietet Zugriff auf verschiedene Datenbanken (z.B. MySQL oder Interbase/Firebird). Das Package wird standardmäßig mit Lazarus installiert (unter Windows). Die Komponenten (TSQLQuery, TSQLTransaction, TIBConnection, TODBCConnection, TOracleConnection, TMySQL40Connection, TMySQL41Connection, TMySQL50Connection, TPQConnection) befinden sich auf der 'SQLdb' Seite in der Komponentenpalette.
  
 
=== dbflaz.lpk ===
 
=== dbflaz.lpk ===
 
Dieses Package bietet Zugriff auf dBase und FoxPro Datenbanken. Weitere Informationen bietet das [[Lazarus Tdbf Tutorial/de|Lazarus TDbf Tutorial]]. Das Package wird standardmäßig mit Lazarus installiert. Die Komponente TDbf befindet sich auf der 'Data Access' Seite in der Komponentenpalette.
 
Dieses Package bietet Zugriff auf dBase und FoxPro Datenbanken. Weitere Informationen bietet das [[Lazarus Tdbf Tutorial/de|Lazarus TDbf Tutorial]]. Das Package wird standardmäßig mit Lazarus installiert. Die Komponente TDbf befindet sich auf der 'Data Access' Seite in der Komponentenpalette.
 
=== interbaselaz.lpk ===
 
Dieses Package bietet Zugriff auf Interbase und Firebird Datenbanken. Es ist den Komponenten bei Delphi nachempfunden, aber bei weitem nicht so umfangreich (enthält nur 3 Komponenten: TIBDatabase, TIBTransaction, TIBQuery). Außerdem erlauben diese Komponenten nur einen Lesezugriff. Das Package muß manuell installiert werden. Voraussetzung dafür ist das Vorhandensein der gds32.dll Datei (unter Windows). Fehlt diese, läßt sich Lazarus nach der Installation des Packages nicht mehr starten. Die Komponenten befinden sich auf der 'Interbase' Seite in der Komponentenpalette.
 
  
 
=== sqlitelaz.lpk ===
 
=== sqlitelaz.lpk ===
Line 67: Line 76:
 
=== sdflaz.lpk ===
 
=== sdflaz.lpk ===
 
Das Package wird standardmäßig mit Lazarus installiert. Die Komponente TSdfDataSet befindet sich auf der 'Data Access' Seite in der Komponentenpalette.
 
Das Package wird standardmäßig mit Lazarus installiert. Die Komponente TSdfDataSet befindet sich auf der 'Data Access' Seite in der Komponentenpalette.
 +
 +
=== lazreport.lpk ===
 +
Mit LazReport enthält Lazarus auch einen Reportgenerator. Dieser basiert auf FreeReport 2.32. Zum Funktionieren von LazReport muss das Package Printer4Lazarus installiert sein.
 +
(Mit Revision 11950 wurde LazReport in das Lazarus SVN Repository übernommen.)
 +
 +
==== lazreportpdfexport.lpk ====
 +
Dieses Package erweitert LazReport um die Möglichkeit, einen Report auch im PDF-Format exportieren zu können.
  
 
== Externe Komponenten / Bibliotheken ==
 
== Externe Komponenten / Bibliotheken ==
  
=== Zeos Bibliothek ===
+
=== Zeos DataBase Objects ===
Diese Bibliothek bietet Zugriff auf verschiedene Datenbanken. Informationen zum Zusammenspiel von Zeos und Lazarus finden sie im [[Zeos tutorial/de|Zeos Tutorial]].
+
Diese Komponenten bieten Zugriff auf verschiedene Datenbanken. Weitere Informationen finden sie [[ZeosDBO|hier]]. Es existiert auch ein [[Zeos tutorial/de|Zeos Tutorial]].
  
 
=== Pascal Data Objects ===
 
=== Pascal Data Objects ===
Die Pascal Data Objects sind von Zeoslib abgeleitet. Es werden die mit MySQL 4.1 und 5.0 eingeführten Funktionen wie prepared statements, binding, und stored procedures von der Datenbank-API namens Pascal Data Objects unterstützt, die durch die PHP Data Objects inspiriert wurde.  Der für die Verwendung dieser neuen API notwendige Code und die Dokumentation sind ein einem Trac wiki zu finden:
+
Die Pascal Data Objects sind von Zeoslib abgeleitet. Es werden die mit MySQL 4.1 und 5.0 eingeführten Funktionen wie prepared statements, binding, und stored procedures von der Datenbank-API namens Pascal Data Objects unterstützt, die durch die PHP Data Objects inspiriert wurde.  Der für die Verwendung dieser neuen API notwendige Code und die Dokumentation sind bei Sourceforge zu finden:
  
https://trac.synsport.com:8000/index.php/pdo/wiki (Benutzername/Passwort sind guest/guest)
+
http://pdo.sourceforge.net
 +
 
 +
Jan 30, 2007: PDO hat Treiber für Firebird 1.5 und Firebird 2.0 hinzugefügt
  
 
--[[User:Jrmarino|Jrmarino]] 11:28, 13 Mar 2006 (CET)
 
--[[User:Jrmarino|Jrmarino]] 11:28, 13 Mar 2006 (CET)
Line 88: Line 106:
 
=== FBLib Firebird Library ===
 
=== FBLib Firebird Library ===
  
[http://fblib.altervista.org/ FBLib] ist eine Open Source Bibliothek (nicht datensensitiv) für direkten Zugriff auf die Firebird relationale Datenbank von Borland Delphi / Kylix, Freepascal und Lazarus aus. Für die meisten Benutzer dürfte es gewöhnungsbedürftig sein, daß hier nicht die übliche Anbindung über TDatasource erfolgt.
+
[http://fblib.altervista.org/ FBLib] ist eine Open Source Bibliothek (nicht datensensitiv) für direkten Zugriff auf die Firebird relationale Datenbank von Borland Delphi / Kylix, Free Pascal und Lazarus aus. Für die meisten Benutzer dürfte es gewöhnungsbedürftig sein, dass hier nicht die übliche Anbindung über TDatasource erfolgt.
  
 
Gegenwärtig sind folgende Features enthalten:
 
Gegenwärtig sind folgende Features enthalten:
  
* Direkter Zugriff auf Firebird 1.0.x 1.5.x Classic oder SuperServer
+
* Direkter Zugriff auf Firebird 1.0.x, 1.5.x und 2.x Classic oder SuperServer
 
* Multiplattform [Win32,Gnu/Linux,FreeBSD)
 
* Multiplattform [Win32,Gnu/Linux,FreeBSD)
 
* Automatische Auswahl der Client Bibliothek 'fbclient' oder 'gds32'
 
* Automatische Auswahl der Client Bibliothek 'fbclient' oder 'gds32'
Line 103: Line 121:
 
* Unterstützt BLOB Felder
 
* Unterstützt BLOB Felder
 
* Export von Daten als HTML SQL Script
 
* Export von Daten als HTML SQL Script
* Service manager (backup,restore,gfix...)
+
* Service manager (backup, restore, gfix...)
 
* Events Alerter
 
* Events Alerter
  
 
Sie können die Dokumentation von der [http://fblib.altervista.org/|FBLib Webseite] herunterladen.
 
Sie können die Dokumentation von der [http://fblib.altervista.org/|FBLib Webseite] herunterladen.
 +
 +
=== Unified Interbase ===
 +
 +
UIB bietet Zugriff auf Interbase, Firebird und YAFFIL Datenbanken. Die Homepage ist [http://www.progdigy.com www.progdigy.com]. Ein SVN-Repository ist verfügbar unter https://uib.svn.sourceforge.net/svnroot/uib .
  
 
=== TechInsite Object Persistence Framework (tiOPF) ===
 
=== TechInsite Object Persistence Framework (tiOPF) ===
Nähere Informationen zu tiOPF sind auf dieser [[tiOPF|Seite]] zu finden.
+
Nähere Informationen zu tiOPF sind auf dieser [[tiOPF/de|Seite]] zu finden.
 +
 
 +
=== Advantage TDataSet Descendant ===
 +
Der Advantage TDataSet Descendant bietet ein Mittel für Verbindungen (und Öffnen von Tabellen) mit dem Advantage Database Server. Advantage ist eine flexible, administrations-freie eingebettete Datenbank, die den Zugriff als Client/Server oder als Peer-to-peer auf die Dateiformate Clipper, FoxPro und Visual FoxPro 9 ermöglicht. Ebenso wie auf das eigene Dateiformat, das einen Migrationpfad darstellt, der es erlaubt, neuere Features zu verwenden.
 +
 
 +
Wichtigste Features:
 +
* Gebührenfreier Peer-to-peer - Datenbankzugriff mit Migrationspfad zu Client/Server
 +
* Multi-Platform (Clients unterstützt unter Windows und Linux, Server unterstützt unter Windows, Linux und NetWare)
 +
* Unterstützt sowohl navigationalen als auch relationalen SQL-Datenbankzugriff
 +
* Volltext-Suchmaschine
 +
* Tabellen-, Index-, Memo- und Kommunikationsverschlüsselung
 +
* Kompatibel mit den originalen TDataset-Komponenten
 +
* Online-Backup
 +
* Server unterstützt Replikation
 +
 
 +
Für weitere Informationen, siehe die [http://www.advantagedatabase.com Advantage Database Server] Website.
 +
 
 +
== Gängige Stolperfallen für Einsteiger / Hinweise zur Fehlersuche ==
 +
===  Fehlermeldung "Operation cannot be performed in an inactive dataset" bei Nachschlagefeldern ===
 +
* Man stelle zunächst sicher, daß das Unit der DataModule vor der des Anwendungsformulars aktiviert wird. Hierzu editiert man die '''projectX.lpr''' und bringt die Create-Zeilen in passende Reihenfolge:
 +
begin
 +
  RequireDerivedFormResource:=True;
 +
  Application.Initialize;
 +
  Application.CreateForm(TDataModule1, DataModule1); //Erst das DataModule!
 +
  Application.CreateForm(TForm1, Form1);
 +
  Application.Run;
 +
end.
 +
                     
 +
* Das Problem kann immer noch auftreten, falls das Dataset der Haupttabelle vor dem Datset der Nachschlagetabelle aktiviert wird. Es ließe sich auf "visuelle" Weise nur verhindern, wenn der Designer eine Möglichkeit böte, die '''Erstellungsreihenfolge ("Creation Order")''' der Komponenten zu definieren. Anders als Delphi bietet Lazarus derzeit (Stand 2017-02) diese Möglichkeit noch nicht.
 +
 
 +
Abhilfe ist trotzdem einfach:
 +
* Vor dem Kompilieren muß man alle Connections im Designer trennen (disconnect). Damit werden auch alle Datasets implizt deaktiviert.
 +
* An geeigneter Stelle [z.B. in .DataModuleCreate des DataModuls oder bei einer nicht lokalen Datenbank noch besser in einer vorgeschalteten Loginprozedur, welche die korrekte Anmeldung und Verbindung zur Datenbank sicherstellt] aktiviert man sie wieder, und im Anschluß lassen sich die Datasets in sinnvoller, definierter Reihenfolge aktiv schalten:
 +
 
 +
  DataModule1.ZConInventory.Connect;
 +
  //Aktivieren der Datasets: Lookup-Datasets zuerst!
 +
  DataModule1.ztNachschlagetabelle.Active := True;
 +
  DataModule1.ztHaupttabelle.Active := True;
 +
  DataModule1.(...)
 +
 
 +
== Siehe auch ==
 +
 
 +
* [[Lazarus DB Faq]]
  
=== LazReport ===
+
[[Category:Databases/de]]
Die Homepage für den Reportgenerator ist [http://lazreport.sourceforge.net/ http://lazreport.sourceforge.net/].
 
Momentan gibt es aber wohl Probleme mit der Wartung der Seite. Weitere Informationen (u.a. ein zusätzlicher Link) sind auch [[Projects_using_Lazarus#LazReport| hier]] zu finden.
 
Zum Funktionieren von LazReport muß das Package Printer4Lazarus installiert sein.
 

Latest revision as of 13:19, 15 February 2017

Deutsch (de) English (en) español (es) français (fr) italiano (it) 日本語 (ja) português (pt) русский (ru) 中文(中国大陆)‎ (zh_CN)

Diese Seite ist noch unfertig ...

Artikel über Datenbank-Programmierung

  • Lazarus-Datenbank-Tutorial - Eine Einführung über die Verwendung von Lazarus mit Datenbanken.
  • Datenbanken - Allgemeine Informationen über die Einsatzmöglichkeiten von Lazarus und FPC mit Datenbanken.
  • Datenbanken mit Lazarus - liefert einen allgemeinen Überblick über die Verwendung von Datenbanken mit Lazarus.
  • How to write in-memory database applications in Lazarus/FPC - Praktische Anweisungen zum programmieren mit MemDatasets
  • MySQLDatabases/de - erklärt, wie man auf eine einfachere Weise eine Verbindung mit einem MySQL Server herstellt.
  • Zeos_tutorial/de - Erzeugen von Datenbank-Anwendungen mit den Zeos-Komponenten.
  • Zeos+SQLite Tutorial - Gutes Tutorial mit Screenshots und Screencasts es wird auf spanisch erläutert, wie SQLite und Zeos, verwendet werden.
  • Pascal Data Objects is a database API that worked for both FPC and Delphi and utilises native MySQL libraries for version 4.1 and 5.0 and Firebird SQL 1.5, and 2.0. It's inspired by PHP's PDO class.
  • Lazarus Tdbf Tutorial/de - Datenbank-Entwicklung unter Verwendung der TDbf-Komponente (entwickelt von Micha Nelissen) mit Lazarus
  • Lazarus DB FAQ (deutsch) - Häufig gestellte Fragen zur Datenbank-Programmierung mit Lazarus.
  • Firebird - Firebird zusamen mit FPC/Lazarus verwenden
  • ODBCConn - Verwendung von 'ODBCConn' unter FPC/Lazarus für Verbindungen zu ODBC-Datenquellen.
  • MS Access - Zugriff auf eine MS-Access Datenbank

Einleitung

Wie bei anderen Entwicklungssystemen auch spielt die Zusammenarbeit mit verschiedenen Datenbanken bei Lazarus eine bedeutende Rolle. Während ein Teil der Funktionalität schon mit FPC zur Verfügung steht, kommen andere Teile (insbesondere die visuellen Komponenten) erst mit Lazarus selbst hinzu. Die bei Lazarus enthaltenen Komponenten decken schon ein gewisses Spektrum an Datenbanken ab. Da aber immer Verbesserungsbedarf besteht und es auch exotischere Datenbanken gibt, existieren externe Komponenten / Bibliotheken, die die Möglichkeiten von Lazarus erweitern.

Diese Seite stellt einen Einstieg für das Thema 'Lazarus und Datenbanken' dar. Die folgende Tabelle bietet einen Überblick über die unterstützten Datenbanken. Da sie noch auf dem Stand von FPC 1.9.7 basiert, sollte sie schnellstens auf den aktuellen Stand gebracht werden. Ein Hinweis noch an alle Experimentierfreudigen: Installieren sie nur die Datenbank-Komponenten, deren Client-Bibliotheken (falls diese erforderlich sind) auf ihrem Computer installiert sind. Sonst kann es passieren, dass Lazarus den Start mit einer Fehlermeldung (wegen fehlender Dateien) verweigert. Da sie somit keine Möglichkeit mehr haben, die Komponenten zu deinstallieren, ist eine Neuinstallation von Lazarus erforderlich.

Tabelle 1

Datenbank Package Name Benötigt eine
Client Bibliothek?
Benötigt Server? Unterstützte Versionen Unterstützte Plattformen
Textdateien SDFLaz Nein Nein - Alle
Im Speicher MemDSLaz Nein Nein - Alle
DBase DBFLaz Nein Nein III+, IV, VII Alle
FoxPro DBFLaz Nein Nein 2.0, 2.5, 3.0 (nicht vollständig) Alle
Paradox TParadoxDataSet Nein Nein bis zu Version 7 (und höher ??) Alle
SQLite SQLite Ja Nein 2.x, 3.x Alle
MySQL SQLdb Ja Ja 3 - 5.5 i386: Linux, Win32
Firebird IBase Ja Depends1) 1 - 2.5 i386: Linux, Win32
PostgreSQL SQLdb Ja Ja 6.6 - 8 i386: Linux, Win32
ODBC SQLdb Ja Depends 3.x 2) i386: Linux, Win32
Interbase IBase Ja Ja 4 - 6 i386: Linux, Win32
Oracle SQLdb Ja Ja - -
Advantage TAdsDataSet Ja Nein 10.1 und höher i386: Linux, Win32

1) Sie können eine eingebettete Version von Firebird zumindest unter Windows benutzen (möglicherweise unter Linux/OSX mit einigen Verrenkungen), oder Sie nehmen eine Server-Version unter Windows/Unix/OSX/FreeBSD/anderen von Firebird unterstützen Plattformen

2) Diese Versionsnummer bezieht sich auf den ODBC Standard, nicht auf die Versionsnummer eines Treibers oder Treibermanagers. Es gibt ODBC 3.x Treiber für die meisten DBMS.

Weitere Informationen zu Lazarus und Datenbanken

Unterschiede zu Delphi

Der vielleicht wichtigste Vorteil von Lazarus gegenüber Delphi ist die Plattformunabhängigkeit. Das bedeutet auf der anderen Seite, dass es für die Windows-spezifischen Teile bei Delphi (z.B. die BDE) keine direkten Entsprechungen bei Lazarus gibt. Gleiches gilt für die meisten Reporting-Werkzeuge. Bei der Konvertierung eines Delphiprogramms nach Lazarus sollte man auf die verschiedenen Dateisysteme achten, wenn das Programm auf allen von Lazarus unterstützten Plattformen laufen soll. Als Beispiel möchte ich nur die unterschiedlichen Trennzeichen im Pfadnamen ( \ bzw. / ) nennen.

In Lazarus enthaltene Datenbank-Packages

sqldblaz.lpk

Dieses Package bietet Zugriff auf verschiedene Datenbanken (z.B. MySQL oder Interbase/Firebird). Das Package wird standardmäßig mit Lazarus installiert (unter Windows). Die Komponenten (TSQLQuery, TSQLTransaction, TIBConnection, TODBCConnection, TOracleConnection, TMySQL40Connection, TMySQL41Connection, TMySQL50Connection, TPQConnection) befinden sich auf der 'SQLdb' Seite in der Komponentenpalette.

dbflaz.lpk

Dieses Package bietet Zugriff auf dBase und FoxPro Datenbanken. Weitere Informationen bietet das Lazarus TDbf Tutorial. Das Package wird standardmäßig mit Lazarus installiert. Die Komponente TDbf befindet sich auf der 'Data Access' Seite in der Komponentenpalette.

sqlitelaz.lpk

Dieses Package bietet Zugriff auf SQLite Datenbanken. Weitere Informationen sind im Lazarus Database Tutorial zu finden.

sdflaz.lpk

Das Package wird standardmäßig mit Lazarus installiert. Die Komponente TSdfDataSet befindet sich auf der 'Data Access' Seite in der Komponentenpalette.

lazreport.lpk

Mit LazReport enthält Lazarus auch einen Reportgenerator. Dieser basiert auf FreeReport 2.32. Zum Funktionieren von LazReport muss das Package Printer4Lazarus installiert sein. (Mit Revision 11950 wurde LazReport in das Lazarus SVN Repository übernommen.)

lazreportpdfexport.lpk

Dieses Package erweitert LazReport um die Möglichkeit, einen Report auch im PDF-Format exportieren zu können.

Externe Komponenten / Bibliotheken

Zeos DataBase Objects

Diese Komponenten bieten Zugriff auf verschiedene Datenbanken. Weitere Informationen finden sie hier. Es existiert auch ein Zeos Tutorial.

Pascal Data Objects

Die Pascal Data Objects sind von Zeoslib abgeleitet. Es werden die mit MySQL 4.1 und 5.0 eingeführten Funktionen wie prepared statements, binding, und stored procedures von der Datenbank-API namens Pascal Data Objects unterstützt, die durch die PHP Data Objects inspiriert wurde. Der für die Verwendung dieser neuen API notwendige Code und die Dokumentation sind bei Sourceforge zu finden:

http://pdo.sourceforge.net

Jan 30, 2007: PDO hat Treiber für Firebird 1.5 und Firebird 2.0 hinzugefügt

--Jrmarino 11:28, 13 Mar 2006 (CET)

TPSQL

Diese Komponenten bieten Zugriff mittels TCP/IP auf PostgreSQL Datenbanken. Weitere Informationen finden sie auf dieser Seite.

FIBL

Diese Komponenten bieten Zugriff auf Interbase und Firebird Datenbanken. Die Homepage ist http://sourceforge.net/projects/fibl.

FBLib Firebird Library

FBLib ist eine Open Source Bibliothek (nicht datensensitiv) für direkten Zugriff auf die Firebird relationale Datenbank von Borland Delphi / Kylix, Free Pascal und Lazarus aus. Für die meisten Benutzer dürfte es gewöhnungsbedürftig sein, dass hier nicht die übliche Anbindung über TDatasource erfolgt.

Gegenwärtig sind folgende Features enthalten:

  • Direkter Zugriff auf Firebird 1.0.x, 1.5.x und 2.x Classic oder SuperServer
  • Multiplattform [Win32,Gnu/Linux,FreeBSD)
  • Automatische Auswahl der Client Bibliothek 'fbclient' oder 'gds32'
  • Abfragen (Queries) mit Parametern
  • Unterstützt SQL Dialekt 1/3
  • LGPL Lizenzvertrag
  • Extrahieren von Metadaten
  • Simple Script Parser
  • Nur 100-150 KB werden zur finalen EXE hinzugefügt
  • Unterstützt BLOB Felder
  • Export von Daten als HTML SQL Script
  • Service manager (backup, restore, gfix...)
  • Events Alerter

Sie können die Dokumentation von der Webseite herunterladen.

Unified Interbase

UIB bietet Zugriff auf Interbase, Firebird und YAFFIL Datenbanken. Die Homepage ist www.progdigy.com. Ein SVN-Repository ist verfügbar unter https://uib.svn.sourceforge.net/svnroot/uib .

TechInsite Object Persistence Framework (tiOPF)

Nähere Informationen zu tiOPF sind auf dieser Seite zu finden.

Advantage TDataSet Descendant

Der Advantage TDataSet Descendant bietet ein Mittel für Verbindungen (und Öffnen von Tabellen) mit dem Advantage Database Server. Advantage ist eine flexible, administrations-freie eingebettete Datenbank, die den Zugriff als Client/Server oder als Peer-to-peer auf die Dateiformate Clipper, FoxPro und Visual FoxPro 9 ermöglicht. Ebenso wie auf das eigene Dateiformat, das einen Migrationpfad darstellt, der es erlaubt, neuere Features zu verwenden.

Wichtigste Features:

  • Gebührenfreier Peer-to-peer - Datenbankzugriff mit Migrationspfad zu Client/Server
  • Multi-Platform (Clients unterstützt unter Windows und Linux, Server unterstützt unter Windows, Linux und NetWare)
  • Unterstützt sowohl navigationalen als auch relationalen SQL-Datenbankzugriff
  • Volltext-Suchmaschine
  • Tabellen-, Index-, Memo- und Kommunikationsverschlüsselung
  • Kompatibel mit den originalen TDataset-Komponenten
  • Online-Backup
  • Server unterstützt Replikation

Für weitere Informationen, siehe die Advantage Database Server Website.

Gängige Stolperfallen für Einsteiger / Hinweise zur Fehlersuche

Fehlermeldung "Operation cannot be performed in an inactive dataset" bei Nachschlagefeldern

  • Man stelle zunächst sicher, daß das Unit der DataModule vor der des Anwendungsformulars aktiviert wird. Hierzu editiert man die projectX.lpr und bringt die Create-Zeilen in passende Reihenfolge:
begin
 RequireDerivedFormResource:=True;
 Application.Initialize;
 Application.CreateForm(TDataModule1, DataModule1); //Erst das DataModule!
 Application.CreateForm(TForm1, Form1);
 Application.Run;
end.
                     
  • Das Problem kann immer noch auftreten, falls das Dataset der Haupttabelle vor dem Datset der Nachschlagetabelle aktiviert wird. Es ließe sich auf "visuelle" Weise nur verhindern, wenn der Designer eine Möglichkeit böte, die Erstellungsreihenfolge ("Creation Order") der Komponenten zu definieren. Anders als Delphi bietet Lazarus derzeit (Stand 2017-02) diese Möglichkeit noch nicht.

Abhilfe ist trotzdem einfach:

  • Vor dem Kompilieren muß man alle Connections im Designer trennen (disconnect). Damit werden auch alle Datasets implizt deaktiviert.
  • An geeigneter Stelle [z.B. in .DataModuleCreate des DataModuls oder bei einer nicht lokalen Datenbank noch besser in einer vorgeschalteten Loginprozedur, welche die korrekte Anmeldung und Verbindung zur Datenbank sicherstellt] aktiviert man sie wieder, und im Anschluß lassen sich die Datasets in sinnvoller, definierter Reihenfolge aktiv schalten:
 DataModule1.ZConInventory.Connect;
 //Aktivieren der Datasets: Lookup-Datasets zuerst!
 DataModule1.ztNachschlagetabelle.Active := True;
 DataModule1.ztHaupttabelle.Active := True;
 DataModule1.(...)

Siehe auch