Firebird (Datenbank)
Infobox_Software
| Name= Firebird
| Logo= 100px|Logo von Firebird
| Screenshot=
| Beschreibung=
| Maintainer=
| Hersteller= Firebird-Entwickler-Team
| AktuelleVersion= 2.1.3
| AktuelleVersionFreigabeDatum= 8. September 2009
| Betriebssystem= Diverse Unixe u. a. AIX, Linux sowie Windows u. a.
| Kategorie= Datenbankverwaltungssystem
| Lizenz= IDPL
| Deutsch= Ja
| Website= www.firebirdsql.org
Firebird ist ein freies Server-Programm und Teil eines Systems zum Betreiben von Datenbanken (DBMS). Es ist der freie Ableger des weiterhin kommerziell von CodeGear (ehemals Borland) vertriebenen relationalen Datenbankmanagementsystems InterBase. Die Abspaltung erfolgte im Jahre 2000, als kurz vor Freigabe der Version 6 des kommerziellen Vorgängers Interbase bei Borland ernsthafte Überlegungen im Gange waren, die Weiterentwicklung einzustellen.
Aus Interbase 6.0 wurde Firebird 1.0, wobei dies als eine Bugfix-Version mit nur wenigen Erweiterungen angesehen werden kann. Eine Erweiterung von Firebird 1.0 ist der 64-Bit File I/O, so dass auch Datenbankdateien von mehr als 2 GB Größe erzeugt werden können.
Grundlegende Erweiterungen erfolgen im Firebird-2.0-Zweig. Der gesamte Quellcode von Interbase wurde aus der Sprache C nach C++ übersetzt. Ab Februar 2004 stand die erste Produktiv-Version aus dem Firebird 2.0-Zweig als Firebird 1.5 zur Verfügung. Im November 2006 wurde Firebird 2.0 freigegeben.
Grundsätzlich ist der Firebird-Server SQL-92-Entry-Level-1-konform. Firebird 1.5 folgt dem SQL-Standard nach ANSI SQL-99. Firebird 2.0 ist überwiegend konform mit SQL-2003 (17 obligatorische Fähigkeiten fehlen ganz, vor allem Schemata; 9 obligatorische Fähigkeiten werden nur teilweise unterstützt).
Verfügbare Varianten des Firebird Datenbankserver-Programms
Die Firebird-Datenbank gibt es in drei Versionen mit unterschiedlichem Funktionsumfang. Es gibt die SuperServer-, ClassicServer- und EmbeddedServer-Variante. Nicht alle Varianten sind für alle Plattformen erhältlich.
; SuperServer: Die SuperServer-Variante ist ein Multithreaded Server-Prozess. Der SuperServer verwaltet alle Benutzeranfragen und Verbindungen mittels von einander unabhängigen Threads innerhalb eines Prozesses. Unter Windows (ab NT4) kann der SuperServer als Dienst laufen oder generell auch als Applikation.
; ClassicServer: Mit dem ClassicServer werden alle Verbindungen in getrennten Prozessen verwaltet. Jeder Prozess verwaltet dabei seinen eigenen Datenbank-Cache. Durch die Trennung nach Prozessen eignet sich der ClassicServer gut für Multiprozessor-Umgebungen. Er verbraucht allerdings mehr Arbeitsspeicher.
; Embedded: Mit der Embedded-Variante ist es möglich, einer einzelnen Applikation exklusiven Zugriff auf eine Datenbank zu ermöglichen. Diese Servervariante eignet sich sehr gut für Einzelanwendungen, die mit einer eigenen Datenbank laufen und keinen Mehrbenutzermodus benötigen. Die Embedded-Version benötigt keine Installation und hat ausschließlich nur eine Programmbibliothek für die verfügbaren Plattformen.
Administration von Firebird-Datenbanksystemen
Für den produktiven 24-Stunden-Betrieb erlaubt das mitgelieferte Backup-Programm (gbak) Online-Backups, ohne eine Datenbank herunterfahren zu müssen. Mit der aktuellen Version 2.0 sind nun auch inkrementelle Sicherungen möglich (nbackup).
Treiber für den Firebird Datenbankserver
Neben dem eigentlichen Datenbankserver gibt es mittlerweile auch Treiber und Bibliotheken für Delphi, Free Pascal, Perl, Python, ODBC, .NET, PHP, Qt, C++ und Java (als Typ2- und Typ4-JDBC-Treiber) für den Zugriff auf die Firebird-Datenbank.
Support kann entweder kostenlos über die Community oder über kommerzielle Angebote erfolgen.
Fähigkeiten von Firebird
Die Firebird-Datenbank beherrscht Gespeicherte Prozeduren mit einer der Oracle-Datenbank recht ähnlichen Programmiersprache (PSQL). Abfragen können ebenfalls gespeichert werden. Gespeicherte Abfragen können Änderungen durchreichen. Kaskadierende Trigger für alle DML-Befehle werden angeboten sowie referentielle Integrität von Fremdschlüsseln. Alle Transaktionen sind voll ACID-kompatibel (Atomicity, Consistency, Isolation und Durability) und unterstützen Sicherungspunkte (SAVEPOINT).
Der Server beherrscht unterschiedliche SQL-Dialekte, die individuell pro Datenbank festgelegt werden können. Abhängig von den Dialekten können zum Beispiel identifizierende Namen beliebige Zeichenketten mit Leerzeichen sein (quoted identifier) oder Namen, die Groß-/Kleinschreibung ignorieren (case insensitive identifier). Mit den unterschiedlichen Dialekten können Daten und Applikationen aus älteren Anwendungen besser migriert werden.
Jede individuelle Spalte einer Tabelle kann ein eigenes Character-Set und eine eigene Sortierung haben (zum Beispiel unabhängig der Groß-/Kleinschreibung). Unterstützt wird eine große Anzahl von vordefinierten 8-Bit-Zeichensätzen und einige Unicode-Varianten. Zusätzliche Zeichensätze und Sortierungen können implementiert werden, ohne etwas am Firebird-Programmquelltext oder dem compilierten Programmcode ändern zu müssen.
Die Server-Umgebung kann Nachrichten aus Triggern und Stored Procedures an Applikationen senden, soweit es die Treiber erlauben. So kann zum Beispiel die aktuelle Betaversion des Java JDBC-Treibers (2.1.0 beta1, Stand: 3. Mai 2006) solche Nachrichten empfangen. Einer Applikation ist es damit möglich auf getriggerte Datenbankänderungen direkt zu reagieren und einem Anwender entsprechende Hinweise zu geben.
Mittels UDFs (User Defined Functions) kann der Sprachumfang der wertverarbeitenden Funktionen erweitert werden. Allerdings müssen entsprechende plattformspezifische Bibliotheken erzeugt und eingebunden werden. In einem experimentellen Stadium befinden sich Embedded Functions, die sich wie Stored Procedures verhalten sollen, aber in beliebigen Programmiersprachen entwickelt werden können. So gibt es zur Zeit eine experimentelle Firebird-Version die Java-Methoden über eine im Server ausgeführte Java Virtual Machine einbinden kann.
Datenbanken können als Nur-Lesend gekennzeichnet werden, um Zugriffe von Archivierungsmedien (z. B. CD-ROM, DVD) zu erlauben. Eine einzelne Datenbankdatei kann bis zu 64 Terabyte groß sein. Eine Datenbank kann aus mehreren Datenbankdateien bestehen. Damit können auch sehr große Datenbanken auf Dateisystemen angelegt werden, die zum Beispiel keine Dateien größer als 2 GB erlauben, beispielsweise FAT 16.
Mittels Software von den Drittanbietern kann Firebird um Replikationsdienste erweitert werden.
Siehe auch
- MySQL
- Drizzle, Ein von MySQL abgespaltenes Datenbankprojekt
- PostgreSQL, eine freie objektrelationale Datenbank
Weblinks
- Firebird Projektseite (englischsprachig)
- The Firebird FAQ (englischsprachig)
Kategorie:Freies Datenbankmanagementsystem
cs:Firebird
da:Firebird (databaseserver)
Firebird (database server)
es:Firebird
fi:Firebird
Firebird (base de données)
he:Firebird
hu:Firebird
id:Firebird
it:Firebird SQL
ja:Firebird
ko:파이어버드 (데이터베이스)
nl:Firebird (database)
no:Firebird
pl:Firebird
pt:Firebird (servidor de base de dados)
ru:Firebird
sr:FirebirdSQL
sv:FirebirdSQL
tr:Firebird (veri tabanı)
uk:Firebird
zh:Firebird (数据库)
Text und Bilder dieses Beitrags stammen aus dem Artikel Firebird (Datenbank) der freien Enzyklopädie Wikipedia und stehen unter der GNU Free Documentation License. Die Liste der Autoren ist in der Wikipedia unter dieser Seite verfügbar, der Original-Artikel lässt sich hier bearbeiten.