Galileo Computing < openbook >
Galileo Computing - Programming the Net
Galileo Computing - Programming the Net


Java ist auch eine Insel (3. Aufl.) von Christian Ullenboom
Programmieren für die Java 2-Plattform in der Version 1.4
Buch: Java ist auch eine Insel
gp Kapitel 20 Datenbankmanagement mit JDBC
  gp 20.1 Das relationale Modell
  gp 20.2 JDBC: der Zugriff auf Datenbanken über Java
  gp 20.3 Die Rolle von SQL
    gp 20.3.1 Ein Rundgang durch SQL-Anfragen
    gp 20.3.2 Datenabfrage mit der Data Query Language (DQL)
  gp 20.4 Datenbanktreiber für den Zugriff
    gp 20.4.1 Treibertypen
  gp 20.5 Datenbanken und ihre Treiber
    gp 20.5.1 Die freie Datenbank MySQL
    gp 20.5.2 JDBC-Treiber für MySQL: MySQL Connector/J
    gp 20.5.3 Die Datenbank Microsoft Access
    gp 20.5.4 Ein Typ-4-Treiber für den Microsoft SQL Server 2000
    gp 20.5.5 Die JDBC-ODBC-Bridge
    gp 20.5.6 ODBC einrichten und Access damit verwenden
    gp 20.5.7 Oracle8i Enterprise Edition
    gp 20.5.8 JDBC-Treiber für mobile Endgeräte
  gp 20.6 Eine Beispielabfrage
  gp 20.7 Mit Java an eine Datenbank andocken
    gp 20.7.1 Der Treibermanager
    gp 20.7.2 Eine Aufzählung aller Treiber
    gp 20.7.3 Log-Informationen
    gp 20.7.4 Den Treiber laden
    gp 20.7.5 Verbindung zur Datenbank
  gp 20.8 Datenbankabfragen
    gp 20.8.1 Abfragen über das Statement-Objekt
    gp 20.8.2 Ergebnisse einer Abfrage in ResultSet
    gp 20.8.3 Unicode in der Spalte korrekt auslesen
    gp 20.8.4 wasNull() bei ResultSet
    gp 20.8.5 Wie viele Zeilen hat ein ResultSet?
  gp 20.9 Java und SQL-Datentypen
    gp 20.9.1 Die getXXX()-Methoden
  gp 20.10 Transaktionen
  gp 20.11 Elemente einer Datenbank hinzufügen und aktualisieren
    gp 20.11.1 Batch-Updates
  gp 20.12 Vorbereitete Anweisungen (Prepared Statements)
    gp 20.12.1 PreparedStatement-Objekte vorbereiten
    gp 20.12.2 Werte für die Platzhalter eines PreparedStatement
  gp 20.13 Metadaten
    gp 20.13.1 Metadaten über die Tabelle
    gp 20.13.2 Informationen über die Datenbank
  gp 20.14 Die Ausnahmen bei JDBC
  gp 20.15 Java Data Objects (JDO)
  gp 20.16 XML-Datenbanken
    gp 20.16.1 Apache Xindice
    gp 20.16.2 eXist und Weitere


Galileo Computing

20.15 Java Data Objects (JDO)toptop

In einer objektorientierten Programmiersprache wie Java liegen alle Informationen in Objekten. Wenn nun relationale Datenbanksysteme im Moment noch in ihrem vollen Saft stehen, dann stellt sich die Frage, wie Java-Objekte in einer relationalen Datenbank untergebracht werden. Die beste Lösung wäre es, eine Zwischenschicht zu besitzen, die Java-Objekte in die Datenbank schreibt. Dabei ist Serialisierung eine Möglichkeit. Das Objekt wird persistent, indem es als serialisierter Bytestrom, als BLOB1 ,in die Datenbank geschrieben wird. Eine andere Möglichkeit ist das objektrelationale Mapping. Die Eigenschaften der Objekte werden auf Relationen und Objektverweise (Referenzen) durch Schlüsselbeziehungen zwischen den Relationen abgebildet.

Eine andere Möglichkeit definiert ein neuer Standard mit dem Namen JDO. Die Abkürzung steht für Java Data Objects, und die Spezifikation beschreibt ein herstellerunabhängiges Framework zur persistenten Speicherung von Java-Objekten in transaktionalen Datenspeichern. Die Spezifikation wurde im Mai 2001 von bekannten Firmen wie Sun, IBM und Apple formuliert. JDO definiert eine einheitliche Schnittstelle für den Zugriff auf persistente Daten, wobei die physikalische Speicherung ziemlich egal ist. Die Objektinformationen können in Dateien, Datenbanken oder sonstigen Systemen abgespeichert werden. Mit Hilfe von JDO kann der Programmierer Datenobjekte ohne Kenntnis der Speichermechanismen bearbeiten. Dies ist für die Entwicklung großer Systeme ein deutlicher Vorteil, denn die Entwickler müssen sich nicht näher mit den Interna von Datenbanken herumärgern, sie können sich auf die reine Applikationslogik konzentrieren. Die einzelnen Hersteller, JDO-Vendor genannt, implementieren eine Speichermöglichkeit für ihr System. Ein Hersteller, der die JDO-Spezifikation schon umgesetzt hat, ist der Datenbankanbieter Poet mit der Fast-Objects-API.

Mittlerweile gibt es auch eine Reihe von Open-Source-Projekten, die sich einer objektrelationalen Umsetzung gewidmet haben. Eines davon ist ObJectRelationalBridge unter http://db.apache.org/ojb/. Das Projekt verspricht eine Unterstützung des gesamten ODMG-3.0-Standards. ODMG ist ein Konsortium, welches einen Standard für die Objekt-Persistenz spezifiziert. Eine JDO-Unterstützung ist in Vorbereitung.






1Ein BLOB (Binary Large OBject) ist großes Binärobjekt, das eine beliebige Anzahl Daten enthalten kann.





Copyright © Galileo Press GmbH 2003
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das <openbook> denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt. Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.


[Galileo Computing] [Buchkatalog] [Neue Bücher] [Vorschau]

Galileo Press GmbH, Gartenstraße 24, 53229 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, info@galileo-press.de