Home / LinuxUser / 2006 / 06 / KDE-Tool als Access-Ersatz

Newsletter abonnieren

Lies uns auf...

Folge LinuxCommunity auf Twitter

Top-Beiträge

Mandriva gibt Distribution in die Hände der Community
(268 Punkte bei 24 Stimmen)
Neues vom Systemd
(179 Punkte bei 5 Stimmen)
Mandriva in Nöten
(161 Punkte bei 4 Stimmen)
Mageia 2 ist fertig
(161 Punkte bei 4 Stimmen)

Heftarchiv

LinuxUser Heftarchiv

EasyLinux Heftarchiv

Ubuntu User Heftarchiv

Ubuntu User Heftarchiv

Partner-Links:

Shopping
Topsuche
 
Yatego Deutschlands größte Shoppingmall. 10000 Shops,
3.5 Mio Artikel. Alle Bestseller, Servertechnik und Technik Themenwelten.

Notebooks und Netzwerkhardware bei Mercateo günstig kaufen.
Internet Telefonie mit VoIP Telefonen von Gigaset
Das B2B Portal www.Linx.de informiert über Produkte und Dienstleistungen.
Günstige Digitalkameras finden Sie im Preisvergleich.

DVD-Verleih

KDE-Tool als Access-Ersatz

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 Datenquelle videos 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.

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/

Einem Freund empfehlen    Druckansicht Bookmark and Share
Kommentare

Hits
Wertung: 0 Punkte (1 Stimme)

Schlecht Gut

Infos zum Autor

Marcel Hilzinger

Marcel Hilzinger

Marcel Hilzinger arbeitet als Redakteur für die Zeitschriften LinuxUser und EasyLinux. Am liebsten schreibt er Artikel zu netten Gadgets oder Multimedia-Software. In seiner Freizeit spielt er gerne Kicker.

Zum Blog von Marcel Hilzinger →


Infos zur Publikation

Infos zur Publikation

LinuxUser 06/2012

Aktuelle Ausgabe kaufen:

Heft bestellen Heft als PDF kaufen

LinuxUser erscheint monatlich und kostet in der Nomedia-Ausgabe EUR 5,50 und mit DVD EUR 8,50. Weitere Informationen zum Heft finden Sie auf der LinuxUser-Homepage.

Im LinuxUser-Probeabo erhalten Sie drei Ausgaben für 3 Euro. Das Jahresabo (ab EUR 56,10) können Sie im LNM-Shop bestellen.

Tipp der Woche

Adobe AIR
Adobe-AIR-Programme installieren und (manuell) starten
Tim Schürmann, 14.05.2012 13:09, 0 Kommentare

Es gibt sie noch: neue Anwendungen, die Adobes Integrated Runtime voraussetzen. Aktuellstes und vermutlich auch größtes Beispiel ist das Adventure Botanicula

Aktuelle Fragen

gibt es ein Kommandozeilen Tool, um ein X11-Fenster in ein Anderes einzubetten?
GoaSkin , 21.05.2012 16:44, 0 Antworten
Das XEmbed-Protokoll ist u.A. dazu gedacht, dass man eine X11-Anwendung in eine andere wie ein Wi...
Apache2, Options -Indexes geht nicht
no no, 12.05.2012 19:01, 8 Antworten
Habe in apache2.conf folgendes stehen: Options -Indexes ...
LInux auf Dell LS H500
Andreas Endresl, 09.05.2012 08:54, 2 Antworten
Habe einen alten Dell Latitude LS H500 nur mit ext. Floppy und CD es geht nur immer eines von den...
Datenwiederherstellung unter Ubuntu 12.04 mit "Simple Backup" nach Umzug von Linux Mint
Christian Lottmann, 07.05.2012 13:33, 0 Antworten
Vor dem Umzug auf Ubuntu 12.04 habe ich unter Linux MInt mit "Simple Backup" voll (15.4.2012) und...
DKMS für den propritären NVIDIA-Treiber
Commander Data, 26.04.2012 22:02, 2 Antworten
Hallo an die Gemeinde. Ich habe hier ein interessantes Stück openSuSE gefunden. http://forums.op...