KDE-Tool als Access-Ersatz

Aus LinuxUser 06/2006

KDE-Tool als Access-Ersatz

© sxc.hu

DVD-Verleih

Knoda ist eines der besten Datenbank-Frontends unter Linux. Version 0.8.1 hat die Treiber für Sqlite, Paradox und MS Access bereits an Bord und bringt zahlreiche Verbesserungen im Abfrageeditor und für Berichte.

Wer sich mit Datenbank-Frontends unter Linux beschäftigt, kommt an Knoda [1] nicht vorbei. Das KDE-Tool unterstützt mit MySQL, PostgreSQL, Xbase, Firebird, SQLite2/3, Paradox, MS Access (nur lesend über die Mdbtools) und einer allgemeinen ODBC-Schnittstelle nicht nur die meisten Datenbanken: Es liefert von allen Datenbank-GUIs unter Linux auch den größten Funktionsumfang. So konvertiert es zum Beispiel per Drag & Drop eine Sqlite3-Datenbank nach MySQL oder PostgreSQL, unterstützt Views und bringt einen komfortablen Abfrageeditor mit. Durch Python-Skripts lassen sich auch komplexe Aufgaben in Knoda leicht lösen.

Zu den wichtigsten Neuerungen der Version 0.8.1 gehört die Unterstützung für Outer Join und Inner Join im grafischen Abfrageeditor (sofern die Datenbank diese Funktion unterstützt). Daneben passen sich Felder in Berichten nun dynamisch dem Inhalt an.

Installation und Start

Knoda aus dem Quellcode zu übersetzen ist einfacher denn je, da die zugehörige Bibliothek hk_classes die Datenbanken Sqlite2/3, Paradox und MS Access bereits unterstützt. Von Access-Datenbanken liest Knoda allerdings weiterhin nur die Tabellen aus. Der Paradox-Treiber erlaubt nun auch Schreibzugriffe auf die Datenbank. Wie Sie Knoda von Hand kompilieren, lesen Sie im Kasten “Knoda aus den Sourcen”.

Benutzer von Suse Linux 9.3 und höher finden auf der Heft-CD fertige RPM-Pakete mit Treibern für MySQL und PostgreSQL. Sind diese Datenbanken auf Ihrem System nicht installiert, bemängelt der Installer fehlende Abhängigkeiten. Möchten Sie Knoda ohne Support für MySQL und PostgreSQL benutzen, installieren Sie die Pakete mit dem Befehl rpm -Uvh *.rpm --nodeps ohne Abhängigkeitskontrolle.

Für Ubuntu befinden sich im Universe-Repository von “Dapper Drake” Knoda-Pakete der Version 0.8.0. “Breezy Badger” kennt erst Version 0.7.4. Der Befehl apt-get install knoda installiert allerdings Knoda nur mit MySQL-Unterstützung. Sie müssen deshalb entweder über apt-get install mysql-server den MySQL-Server nachinstallieren oder per apt-get install libhk-classes-sqlite die Unterstützung für SQLite2 nachrüsten. Möchten Sie auch die Skripting-Funktionen mit Python benutzen, fehlt zudem noch das Paket python-hk-classes.

Alternativ laden Sie sich von der Heft-CD oder der Knoda-Homepage den Sourcecode von hk_classes und knoda herunter und kompilieren das Programm selbst (siehe Kasten “Knoda aus den Sourcen”). In den meisten Fällen klappt das problemlos.

Knoda aus den Sourcen

Knoda dient genau genommen bloß als hübsche Karosserie. Den eigentlichen Motor für das KDE-Programm liefert hk_classes. Diese Bibliothek unterstützt mittlerweile neun verschiedene Datenbanktypen, drei davon sind seit Version 0.8.1 fester Bestandteil von hk_classses.

Die Zahl der effektiv vorhandenen Datenbanktreiber hängt davon ab, welche Entwicklerpakete die zugehörige Bibliothek hk_classes beim Kompilieren findet. Übersetzen Sie das Programm auf einem Rechner, der zum Beispiel die Pakete mysql-devel und postgresql-devel mitbringt, zeigt Knoda später in der Liste der unterstützten Datenbanken diese zwei zusätzlichen Einträge an.

Wissen Sie bereits im Vorfeld, mit welchen Datenbanken Sie arbeiten möchten, lohnt es sich deshalb, hk_classes und knoda (in dieser Reihenfolge) aus dem Quellcode zu erstellen. Dazu genügen die Befehle ./configure, make und (als Root) make install. Achten Sie dabei auf die Ausgabe des Configure-Skripts von hk_classes. Es zeigt Ihnen an, welche Datenbanken Knoda unterstützen wird. Ist die gewünschte Datenbank nicht mit dabei, müssen Sie das entsprechende Entwicklerpaket nachinstallieren. Dieses heißt in der Regel Datenbank-devel oder libDatenbank, wobei Sie Datenbank durch den richtigen Namen ersetzen müssen.

Beim Kompilieren von Knoda teilen Sie dem Configure-Befehl über den Zusatz --prefix=/pfad/zu/kde zusätzlich mit, wo Ihre Distribution die KDE-Dateien ablegt. Unter Suse Linux lautet der volle Befehl ./configure --prefix=/opt/kde3. Bei den meisten anderen Distributionen führt der Befehl ./configure --prefix=/usr zum Ziel.

Den passenden Präfix ermitteln Sie über den Befehl kde-config --prefix. Die Bibliothek hk_classes ist kein KDE-Programm. Sie darf deshalb nicht mit dem KDE-Präfix übersetzt werden. Das Kompilieren von Bibliothek und GUI dauert je nach Leistungsfähigkeit des Rechners zwischen 30 und 90 Minuten.

Datenbank anlegen

Nach dem Start von Knoda durch den Befehl knoda auf der Kommandozeile erscheint das Hauptfenster des Programms mit dem Treiberauswahldialog im Vordergrund. Hier wählen Sie den gewünschten Datenbanktreiber aus und klicken auf Verbinden (Abbildung 1). Je nach verwendetem Treiber erscheint im Anschluss ein Passwort-Dialog oder gleich das Hauptfenster von Knoda. Für folgende Anleitung empfehlen wir Ihnen, wenn möglich MySQL oder PostgreSQL als Datenbank zu nutzen, da Knoda damit wesentlich schneller arbeitet und nachträgliche Veränderungen an den Tabellen jederzeit möglich sind. Die vorgestellte Lösung lässt sich aber auch über SQLite verwirklichen.

Abbildung 1: Beim Start von Knoda wählen Sie den Datenbanktreiber aus.

Abbildung 1: Beim Start von Knoda wählen Sie den Datenbanktreiber aus.

Wählen Sie nun Datei | Neu | Datenbank, um eine neue Datenbank anzulegen. Per Klick mit der rechten Maustaste auf den Eintrag Tabellen erstellen Sie dann zwei Tabellen für den geplanten DVD-Verleih. Die Tabelle videos soll die Liste der DVD-Filme enthalten, die Tabelle kontakte die Benutzerdaten. Als gemeinsames Feld verbindet die zwei Tabellen die Ausleih-ID AID. Sofern Sie nicht mit Sqlite arbeiten, können Sie die Tabellen später um beliebige Felder erweitern. Sqlite lässt leider an der einmal gespeicherten Tabellenstruktur keine Änderungen mehr zu. Um die Tabellen mit Daten zu füllen, wechseln Sie vom Entwurfsmodus in den Anzeigemodus. Details zum Erstellen von Datenbanken und Tabellen entnehmen Sie über [F1] der Online-Hilfe oder den Workshops unter [2] und [3].

Mit Hilfe eines Formulars soll nun die Zuordnung von Film und Ausleiher erfolgen. Erstellen Sie dazu über Datei | Neu | Formular ein neues Formular und fügen Sie anschließend die beiden neu erstellten Tabellen als Datenquelle hinzu. Dazu klicken Sie auf den Button mit drei Punkten hinter der Dropdown-Liste Datenquelle und wählen jeweils eine Tabelle aus. Einen ausführlichen Artikel, wie man in Knoda Formulare erstellt, finden Sie auch unter [4].

Wählen Sie nun über die Dropdown-Liste als Datenquelle für das leere Format die Tabelle videos aus. Das ist wichtig, damit der Datensatzselektor am unteren Fensterrand funktioniert. Fügen Sie ein erstes Editierfeld ein und wählen Sie als Datenquelle die Tabelle videos und als Feld den Eintrag mit dem Titel der DVD. Als zweites Feld soll eine Combobox die Auswahl des Entleihers ermöglichen. Es schreibt die AID des Ausleihers in die Tabelle videos.

Klicken Sie dazu auf den Combobox-Knopf und wählen Sie dann als Datenquelle das FeldAID der Tabelle videos. Das bedeutet, dass die gewählten Einträge in dieser Tabelle gespeichert werden. Als Listendatenquelle wählen Sie die Tabelle kontakte mit dem ListenfeldAID. Unter angezeigtes Feld wählen Sie die den Namen des Kontakts. Die detaillierten Einstellungen für die Combobox zeigt Abbildung 2.

Abbildung 2: Die Combobox liest die Ausleiher-ID aus der Tabelle <code srcset=

kontakte und schreibt die AID in die Tabelle videos.” width=”217″ height=”300″ /> Abbildung 2: Die Combobox liest die Ausleiher-ID aus der Tabelle kontakte und schreibt die AID in die Tabelle videos.

Wechseln Sie nun in den Ansichtsmodus, so zeigt Knoda im oberen Feld die Titel der DVD-Filme an. In der Combobox sehen Sie den Entleiher und können einen neuen festlegen (Abbildung 3). Die Navigation durch die Datensätze erfolgt über das Kontrollelement am unteren Fensterrand. Wählen Sie aus der Dropdown-Liste einen neuen Kontakt aus, aktualisiert Knoda bei einem Klick auf den nächsten Datensatz die Informationen. Alternativ legen Sie einen separaten Button an, um die Änderungen zu speichern.

Abbildung 3: Das Formular für den DVD-Verleih ist noch ziemlich leer, bringt aber bereits grundlegende Funktionen mit.

Abbildung 3: Das Formular für den DVD-Verleih ist noch ziemlich leer, bringt aber bereits grundlegende Funktionen mit.

Rückgabe

Natürlich möchten Sie Ihre DVDs nicht nur ausleihen, sondern auch wieder einmal zurückerhalten. Die Aufgabe lässt sich auf zwei Arten lösen: Für die einfache Methode legen Sie in der Tabelle kontakte einen leeren Benutzer an, der 0 als AID hat. Sie können dann über die Combobox einfach den leeren Eintrag auswählen.

Die elegantere Lösung benutzt die Scripting-Funktionen von Knoda. Legen Sie dazu einen neuen Button an, wählen Sie als Datenquellevideos und setzen Sie das Label, zum Beispiel Rückgabe. Bei einem Klick auf den Button soll Knoda nun das AID-Feld der Video-Tabelle auf Null zurücksetzen. Wechseln Sie dazu im Eigenschaftsdialog auf den Reiter Aktionen und Klicken Sie hinter Bei Klick auf den Button nicht gesetzt. Knoda öffnet einen Editor, in dem Sie die folgenden zwei Zeilen eintragen:

col=hk_this.datasource().column_?
by_name("AID")
col.set_asstring("0")

Die erste Zeile teilt Knoda mit, dass es die Spalte AID bearbeiten soll. Zeile 2 setzt dann für diese Spalte den Wert 0. Nach dem Schließen des Editors zeigt der Button hinter Bei Klick nun Gesetzt an. Zum Test wechseln Sie in den Ansichtsmodus, wählen einen Eintrag aus, bei dem die Ausleihe aktiv ist, und klicken dann auf den Rückgabe-Button. Wechseln Sie auf den nächsten Datensatz und wieder zurück, ist der Eintrag genullt.

Möchten Sie gleich zum nächsten Datensatz wechseln, um zum Beispiel mehrere Rückgaben hintereinander vorzunehmen, fügen Sie dem bereits erstellten Skript folgende wwei Zeilen an:

ds=hk_this.datasource()
ds.goto_next()

Das Formular springt dann bei der Rückgabe automatisch auf den nächsten Datensatz.

Daten sortieren

In der Grundeinstellung zeigt das Formular die Ausleihen in der Reihenfolge auf, in der Sie die DVDs in die Datenbank aufgenommen haben. Das ist nicht praktisch, wenn Sie die Rückgaben eines Kontakts nacheinander bearbeiten möchten. Über ein weiteres Skript lässt sich die Sortierung der Tabelle videos dynamisch ändern. Legen Sie dazu einen neuen Button an und fügen Sie dann auf dem Reiter Aktionen unter Bei Klick folgendes Skript ein:

ds=hk_this.datasource()
ds.set_sorting("AID ASC")

Alternativ fügen Sie die zweite Zeile des Skripts dem Button Rückgabe hinzu. Die einmal vorgenommene Sortierung merkt sich Knoda, sodass beim nächsten Öffnen der Datei die Reihenfolge automatisch stimmt.

Über weitere Buttons können Sie zum Beispiel eine Benutzerverwaltung aufrufen, um neue Kontakte anzulegen oder ein weiteres Unterformular, um der Datenbank neue DVD-Filme hinzuzufügen. Ein Beispiel zeigt Abbildung 4. Die gezeigte Datenbank finden Sie im Sqlite3-Format auch auf der LinuxUser-Homepage zum Download [5].

Abbildung 4: Das fertige Formular für die DVD-Verwaltung – eigentlich bereits ein kleines Programm für sich.

Abbildung 4: Das fertige Formular für die DVD-Verwaltung – eigentlich bereits ein kleines Programm für sich.

Glossar

Outer Join

Verknüfung zwischen Datenbank-Tabellen. Bei einem Inner Join werden nur die Datensätze angezeigt, die in direkter Beziehung zueinander stehen; bei einem Outer Join auch Datensätze, die keinen direkten Bezug zu Datensätzen der anderen Tabelle haben.

Inner Join

Verknüfung zwischen Datenbank-Tabellen. Bei einem Inner Join werden nur die Datensätze angezeigt, die in direkter Beziehung zueinander stehen; bei einem Outer Join auch Datensätze, die keinen direkten Bezug zu Datensätzen der anderen Tabelle haben.

SQLite

Programmbibliothek, die ein relationales Datenbanksystem beinhaltet. Das für zahlreiche Betriebssysteme verfügbare SQLite speichert die Daten in einer lokalen Datei, ist also eine Art eingebautes Datenbanksystem.

Infos

[1] Homepage: http://www.knoda.org

[2] Knoda-Workshop, Teil 1: Marcel Hilzinger, “Bankgeheimnis”, LinuxUser 01/2005, S. 70

[3] Knoda-Workshop, Teil 2: Marcel Hilzinger, “Schön sortiert”: LinuxUser 02/2005, S. 75

[4] Knoda als Access-Ersatz: Marcel Hilzinger, “Vom Nordwind zum Südsturm”, LinuxUser 08/2005, S. 60

[5] Beispiel-Datenbank: http://www.linux-user.de/Downloads/2006/06/knoda/

LinuxUser 06/2006 KAUFEN
EINZELNE AUSGABE
ABONNEMENTS
TABLET & SMARTPHONE APPS
E-Mail Benachrichtigung
Benachrichtige mich zu:

Hinweis: Dieser Artikel ist älter als ein Jahr, enthaltene Informationen sind möglicherweise veraltet.

0 Kommentare
Älteste
Neuste Beste Bewertung
Inline Feedbacks
Alle Kommentare anzeigen
Nach oben