Databases/de

From Free Pascal wiki
Revision as of 17:05, 21 May 2006 by Swen (talk | contribs)
Jump to navigationJump to search

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

Arbeit ist im Gange..

Einführung

Diese Seite handelt über die Erzeugung von Datenbank Anwendungen mit Lazarus unter Verwendung der DB Unit. In der DB Unit ist die grundlegende Funktionalität für die Arbeit mit Datenbanken implementiert, aber um sie nutzen zu können, brauchen sie Komponenten, welche von der Datenbank abhängen, die sie benutzen wollen.

Der erste Teil bietet eine kurze Einführung über verschiedene Datenbank-abhängige Komponenten und wie man sie installiert, der zweite Teil ist ein kurzer Kursus im Arbeiten mit der DB Unit und der letzte Teil bietet spezifische Informationen über verschiedene unterstützte Datenbanken.

Erster Teil: Allgemeine Informationen über unterstützte Datenbanken

Einleitung

Die Datenbanken, die sie mit Lazarus benutzen können, (eigentlich mit FPC, aber das ist nicht so wichtig für den Rest der Geschichte) lassen sich in zwei Kategorien unterteilen: Die Datenbanken, die komplett 'intern' sind und in Freepascal geschrieben, und die 'externen' Datenbanken, zu denen die Verbindungen mit Client-Bibliotheken hergestellt werden. Um diese Client-Bibliotheken zu benutzen, müssen die passenden Verbindungen verfügbar sein. Die meisten Client-Bibliotheken kommen nur mit Verbindungen für C, aber FPC bietet verschiedene Packages mit den Pascal-Verbindungen für Datenbank Clients. Die unterstützten Datenbanken sind in Tabelle 1 aufgelistet (Stand FPC 1.9.7).

Tabelle 1

Datenbank Package Name Need client lib? Need server? Unterstützte Versionen Unterstützte Plattformen
Textdateien sdf Nein Nein - Alle
Im Speicher memds Nein Nein - Alle
DBase tDbf Nein Nein III+, IV, VII Alle
FoxPro tDbf Nein Nein - Alle
SQLite SQLite Ja Nein - -
MySQL MySQL Ja Ja 3 - 4.0 i386: Linux, Win32
Firebird IBase Ja Ja 1 - 1.5 i386: Linux, Win32
PostgreSQL postgres Ja Ja 6.6 - 8 i386: Linux, Win32
ODBC ODBC Ja Depends - i386: Win32
Interbase IBase Ja Ja 4 - 6 i386: Linux, Win32
Oracle Oracle Ja Ja - -

Die Anbindungen zu den Datenbank-Clients

Wenn sie eine der Datenbank Client-Bibliotheken benutzen wollen, müssen diese Bibliotheken installiert sein. Nicht nur auf dem Computer, auf dem sie programmieren, sondern auch auf den Computern, auf denen die Anwendung laufen muß. Beachten sie, daß einige Datenbanken (im besonderen MySQL) nur arbeiten, wenn die Bindungen, die in die Applikation einkompiliert sind, identisch mit den installierten Bibliotheken sind. Wie man diese Bibliotheken installiert (.so Dateien bei *nix Systemen, und .dll's bei Windows), können sie auf der Internetseite der Datenbank-Entwickler finden. Die binding Units finden sie im packages/base Verzeichnis in den FPC Quellen. Sie bestehen hauptsächlich aus Client-API Aufrufen wie mysql_connect_database, welche völlig verschieden sind für jede Datenbank. Es ist möglich, Datenbank-Anwendungen unter Verwendung dieser Units zu schreiben, aber es ist meistens weit mehr Arbeit und fehleranfälliger als die Verwendung der DB-Unit Lazarus Komponenten.

Die meisten dieser Bindungspakete sind mit den Client-Bibliotheken hart verlinkt. Das bedeutet, daß wenn die Anwendung mit einer dieser Units darin kompiliert wurde, die ganze Anwendung nicht gelinkt werden kann falls die Clientbibliotheken nicht auf der Workstation verfügbar sind. Wenn sie - zum Beispiel - MySQL nicht auf ihrem Computer installiert haben, und sie die mysql4.pp Unit in ihrem Programm verwenden, würde das Programm nicht gelinkt. Wenn es ihnen gelingt, das Programm zu kompilieren auf einem Computer, auf dem MySQL installiert ist, würde es dennoch nicht starten auf jeder anderen Workstation ohne die zugehörigen MySQL-Bibliotheken.

Um solche Probleme zu vermeiden sind einige der Packages in der Lage, sich dynamisch zu den Bibliotheken zu linken. Bevor irgendein Aufruf dieser Bibliotheken erfolgen kann, muß die Unit 'initialisiert' werden. Diese Initialisierung schlägt fehl, wenn der Datenbank-Client nicht auf dem Computer installiert ist. Wenn das Programm bereit ist, die Client-Bibliothek zu benutzen, muß die Unit 'released' werden.

Die Datenbank-Komponenten in Lazarus

Zweiter Teil: Benutzung der Komponenten in der DB Unit

Dieser Abschnitt bietet ein kurzes Tutorial, welches für alle Datenbanken gilt, die auf der DB Unit basieren. Bevor sie die DB Unit benutzen können, muß eine Datenbank-Komponente installiert sein. Als Beispiel wird Tdbf genutzt, aber jeder TDataset Nachfahre könnte genutzt werden.

Schritt eins: Erzeugen sie eine neue Lazarus Anwendung

Schritt zwei: Legen sie eine Tdbf Komponente auf ihrem Formular ab. (oder jeden anderen TDataset Nachfahren natürlich) Dieser TDataset-Nachfahre dient dazu, Daten in einer Tabelle oder Query abzurufen.

Schritt drei: Legen Sie eine Tdbf und eine TDatasource Komponente auf ihrem Formular ab. Die Tdbf dient dazu, Daten in einer Tabelle oder Query abzurufen, die TDatasource ist das Bindeglied zwischen TDataset und den sichtbaren Komponenten auf dem Formular, wie TDBEdit. Die beiden Komponenten verbindet man miteinander, indem man die 'Dataset' Eigenschaft von TDatasource auf das TDataset setzt. (In diesem Fall: Dbf1)



--Loesje 14:39, 10 Feb 2005 (PST)