Kapitel 23. Datenbank

Tony Bloomfield

Version 4.6 (2011-07-21)

Relationale Datenbank verwenden

Einleitung

Seit der Version 1.0 ermöglicht es KMyMoney, Ihre Daten in einer relationalen Datenbank zu speichern. Ein Vorteil der Nutzung dieses Industriestandards ist, dass Sie mit anderen Softwareprodukten auf Ihre Daten zugreifen und sie visualisieren können, z.B. mit OpenOffice© oder LibreOffice©, vielleicht in einem Format, das KMyMoney derzeit noch nicht bietet. Ein wenig SQL-Kenntnisse (SQL - Structured Query Language, die weltweit verwendete Standardsprache, um auf relationale Datenbanken zuzugreifen) sollten es Ihnen erleichtern, Ihre Daten zu externen Programm zu exportieren, z. B. zu Budgetierungs-Programmen.

Vorbereitung

Um auf die Datenbank zuzugreifen, nutzt KMyMoney das SQL-Modul der Qt™ Software als Teil der Qt™-Bibliotheken. Dieses Modul unterstützt diverse Datenbanksysteme durch eine Auswahl an Datenbanktreibern. Für verbreitete Open-Source Systeme sind diese Treiber verfügbar: MySQL®, SQLite (Nur Version 3 und höher) und PostgreSQL. Das Modul unterstützt ebenso größere, vorwiegend in der Industrie genutzte Systeme, wie Oracle® und IBM DB2®.

Mit Ausnahme von SQLite arbeiten alle Systeme nach dem Client/Server Modell, wobei die Client-Software auf "Ihrer" Maschine läuft, während der Server auf der gleichen Maschine läuft wie die eigentliche Datenbank, welche aber auch irgendwo anders im Netzwerk platziert werden kann. Natürlich wird Ihr Computer bei KMyMoney als "Persönlicher Finanzmanager" in einem normalen Szenario sowohl als Server, als auch Client fungieren. Nachdem Sie sich für ein Datenbankprodukt entschieden haben, ist der Schritt die Installation die Installation der Client und i.d.R. auch Server-Software.

Zusätzlich zur eigentlichen Datenbanksoftware müssen Sie das entsprechende Qt™-Treibermodul installieren. Die meisten Distributionen bieten passende Treibermodule für die bekannten Datenbanken an. Ansonsten schauen Sie auf die Qt™-Software-Webseite und suchen Sie dort nach SQL-Treibern.

Anmerkung

SQLite arbeitet nicht nach dem Client-/Server-Modell. Jede Datenbank befindet sich in einer herkömmlichen Datei, lokal oder in einem Netzwerk, auf die über die normalen Dateizugriffsfunktionen des Betriebssystem zugegriffen wird. In diesem Fall ist nur ein Softwarepaket und der Datenbanktreiber zu installieren. Weiterhin sind einige der nachfolgenden Informationen, speziell zur Administration, nicht für SQLite relevant.

Verwaltung

Datenbanken sind etwas komplexer als die Verwendung einfacher Dateien. Jedes System hat unterschiedliche Methoden zur Verwaltung der Datenbank, wie das Erzeugen einer neuen Datenbank, die Zuordnung von Zugriffsrechten für verschiedene Datenbankbenutzer, das Erstellen von Datensicherungen, usw. Diese Dinge werden nicht in diesem Handbuch beschrieben, aber für alle der unterstützten Datenbankprodukte sind im Internet eine Vielzahl an Anleitungen und Handbücher zu finden.

Die Datenbank erstellen

Es wird Code bereitgestellt, um eine initiale Datenbank, die Ihre Daten aufnehmen wird, zu erzeugen, wenn noch keine existiert. Es wird dringend angeraten, dass Sie vorher eine Datenbank erstellen, da die meisten Datenbankprodukte eine Vielzahl an Optionen verwendet, die relevant sein können. Eine solche wichtige Eigenschaft ist der verwendete Zeichensatz (z. B. UTF-8) für Textfelder.

Zum gleichen Zeitpunkt müssen Sie auch Zugriffsrechte für verschiedene Datenbanknutzer definieren, um unterschiedliche Datenbankoperationen durchführen zu können. Bei den meisten Systemen wird dem Benutzer, der die Datenbank anlegt, automatisch sämtliche Rechte auf die Datenbank eingeräumt, aber näheres hierzu finden Sie in der Dokumentation der von Ihnen verwendeten Datenbank.

Beim ersten Zugriff auf die Datenbank, und evtl. zu einem späteren Zeitpunkt wenn sich die Datenbankstruktur ändert, benötigen Sie Rechte (auch Privilegien, eng. "privileges" genannt), um Tabellen und Ansichten (views) anzulegen und zu ändern. Es können verschiedene Bezeichnung für diese Rechte bei den unterschiedlichen Datenbankprodukten verwendet werden, aber meist ist die Rede von CREATE und ALTER. Für die tägliche Arbeit benötigen Sie Zugriffsrechte zum Lesen und Schreiben von Datensätzen. Diese werden in SQL als SELECT, INSERT, UPDATE und DELETE Berechtigungen bezeichnet.

Tabellen erstellen

Bei der ersten Verwendung wird KMyMoney versuchen, die benötigten Tabellenstrukturen anzulegen. Um eine größtmögliche Kompatibilität zu möglichst vielen Datenbanken zu erreichen, wird nur eine Teilmenge von gängigen Datentypen verwendet. Nichtsdestotrotz kann es vorkommen, dass ein bestimmter Datentyp von Ihrem Datenbankprodukt nicht unterstützt wird. In diesem Fall müssen Sie den notwendigen SQL-Code zur Erzeugung der Tabellen selbst bereitstellen. Dieser Code kann dann nach den eigenen Bedürfnissen modifiziert werden und außerhalb von KMyMoney zur Erzeugung der Tabellen verwendet werden. Sollten Sie sich in einer solchen Situation befinden, wird Ihnen in der sicherlich geholfen. Weitere Informationen finden Sie unter Manuelle Erstellung der Datenbank.

Erstellen einer Datenbank

Öffnen oder importieren Sie eine existierende Datei in KMyMoney, oder erzeugen Sie eine Neue. Anschließend wählen Sie Speichern in Datenbank aus dem Menü Datei. Dann öffnet sich folgendes Dialogfenster:

Vervollständigen Sie die Eingaben für den ausgewählten Datenbanktyp, Pflichtfelder werden hervorgehoben. Klicken Sie dann auf OK, um die Datenbank zu erstellen.

Datenbank-Typ

Dieses Auswahlfeld zeigt alle Qt™-SQL-Treiber, die auf Ihrem System installiert sind, Wählen Sie den für Ihre Datenbank passenden Treiber aus. Wenn ein passender Treiber nicht in der Liste aufgeführt wird, müssen Sie ihn installieren. Schauen Sie in der Dokumentation zu Ihrer Distribution, oder besuchen Sie die Qt™-Software-Webseite und suchen Sie nach "SQL drivers".

Datei (nur SQLite)

SQLite speichert eine Datenbank in einer Datei, geben Sie daher den Dateinamen für die Datenbank an. Klicken Sie auf das Symbol rechts neben dem Eingabefeld, damit öffnen Sie den Dateidialog, mit dessen Hilfe Sie eine bestehende Datei auswählen oder eine neue Datei erzeugen können. Für SQLite Datenbanken sind die Felder Rechnername, Benutzername und Passwort nicht relevant. Die SQLite-Datei muss die entsprechenden Schreib-/Leserechte auf der Betriebssystemebene besitzen, damit der gerade angemeldete Benutzer darauf zugreifen kann.

Datenbank-Name (Andere)

Der Datenbankname ist in der Voreinstellung "KMyMoney", aber Sie können auch einen anderen wählen. Für einige Datenbanken ist KMyMoney eventuell nicht in der Lage, die Datenbank zu erzeugen, sodass sie vorher mit den zugehörigen Programmen erstellt werden muss. Normalerweise kann KMyMoney die benötigten Tabellenstrukturen generieren. Funktioniert es doch einmal nicht, müssen Sie dies manuell durchführen. Weitere Informationen dazu finden Sie im Abschnitt Manuelle Erstellung der Datenbank.

Rechnername

Für den normalen Benutzer ist der vorgegebene Name localhost, der für Ihren Rechner steht an dem Sie gerade arbeiten, korrekt. Für eine Datenbank im Netzwerk müssen Sie den entsprechenden Rechnernamen eingeben.

Benutzername und -passwort

In den Einstellungen der Zugriffsrechte in Ihrer Datenbank finden Sie die notwendigen Informationen, die Sie hier eintragen müssen, oder kontaktieren Sie Ihren Datenbankadministrator. Der hier eingegebene Datenbankbenutzer muss die Berechtigungen für SELECT, INSERT, UPDATE und DELETE haben. Wenn der Benutzername der gleiche ist wie Ihr Anmeldungs-Name, ist ein Passwort normalerweise nicht notwendig.

Auf Ihre Daten zugreifen

Tabellenentwurf

Um auf Ihre Daten in KMyMoney zuzugreifen, wählen Sie aus dem Menü Datei den Menüpunkt Datenbank öffnen .... Es öffnet sich ein ähnliches Dialogfenster wie oben beschrieben.

Anmerkung

Haben Sie Ihre Datenbank erstellt, indem Sie zuerst eine Datei geöffnet haben und dann wie vorher beschrieben die Funktion Speichern in Datenbank benutzt haben, dann werden alle nachfolgenden Änderungen nur noch in der Datenbank, aber nicht mehr in der Datei gespeichert. Damit können Sie die Datei als Sicherung oder Momentaufnahme Ihrer Daten zu einem bestimmten Zeitpunkt verwenden. Um wie vorher eine neue Sicherung zu erstellen, öffnen Sie die Datenbank, benutzen die Aktion DateiSpeichern unter ... und vergeben einen passenden Dateinamen. Öffnen Sie dann wieder die Datenbank, damit KMyMoney alle Änderungen darin und nicht in der Datei speichert.

Um auf Ihre Daten in anderen Formaten zuzugreifen, müssen Sie wissen, wie sie in der relationalen Datenbank gespeichert sind. Am einfachsten ist es, die Datenbank mit einem Programm wie OpenOffice zu öffnen. Sie werden eine Liste der verschiedenen Tabellen sehen, aus denen die Datenbank besteht. Weiterhin können Sie sich die Tabellenstrukturen anschauen.

Um Daten z. B. in eine Tabellenkalkulation oder eine externe Datei zu extrahieren ist es meist unausweichlich, die Daten nicht nur aus einer, sondern aus mehreren Tabellen auszulesen. Dies wird erreicht, in dem die Tabellen miteinander Verknüpft werden (engl. JOIN). Die verknüpften Tabellen müssen jeweils Felder mit identischen Inhalten haben. Viele weitere Informationen über diese grundlegenden Themen finden Sie in den weiter oben schon erwähnten Anleitungen. Die nachfolgende Tabelle listet alle Felder auf, die für die Tabellenverknüpfungen verwendet werden.

Beziehung

Übereinstimmung

mit

Geldinstitute und Konten

kmmInstitutions.id

kmmAccounts.institutionId

Über-/untergeordnete Konten

kmmAccounts.id

kmmAccounts.parentId

Buchungen und Split-Buchungen (siehe Fußnote 1)

kmmTransactions.id

kmmSplits.transactionId

Konten und Split-Konten

kmmAccounts.id

kmmSplits.accountId

Empfänger und Split-Buchungen

kmmPayees.id

kmmSplits.payeeId

Geplante Buchungen und Buchungen

kmmSchedules.id

kmmTransactions.id

Buchungen und Währungen

kmmTransactions.currencyId

kmmCurrencies.ISOCode

Konten und Wertpapiere (siehe Fußnote 2)

kmmAccounts.currencyId

kmmSecurities.id

Wertpapiere und Preise

kmmSecurities.id

kmmPrices.fromId oder kmmPrices.toId

Währungskurse

kmmCurrencies.ISOCode

kmmPrices.fromId oder kmmPrices.toId

Fußnoten:

1 – txType = “N” für normale Buchungen, “S” für geplante Buchungen

2 – wenn kmmAccounts.isStockAccount = “Y”

Feldformate

Einige Datenfelder werden in einem internen Datenformat vorgehalten, welche nicht direkt für externe Programme nutzbar sind. In diesen Fällen werden die Informationen doppelt, einmal im internen und externen Format, vorgehalten.

Geldbeträge und Aktienkurse werden beide im Format Zähler/Nenner und zusätzlich, wenn der Feldname mit dem Suffix "Formatted" beginnt, in dem Format wie Sie es am Bildschirm sehen, gespeichert.

Ebenso werden einige Felder, wie z. B. der Kontotyp, sowohl als numerische ID als auch zusätzlich in einem Feld mit der Nachsilbe "String" im Format und Sprache der Anwendung gespeichert.

Ihre Daten aktualisieren

Da Ihre Daten in einem Standardformat gespeichert sind, können Sie diese auch mit anderen Programmen als KMyMoney bearbeiten. Möchten Sie das wirklich tun, sollten Sie stets eine Sicherung Ihrer Daten erstellen. Wenn etwas schief geht, wird KMyMoney nicht mehr in der Lage sein, Ihre Daten zu lesen und im schlimmsten Fall wären diese komplett verloren.

Gespeicherte Abfragen

Viele Datenbanksysteme erlauben es, gemeinsam genutzte Abfragen und Prozeduren zu hinterlegen. In einigen Fällen werden diese als Tabellen oder andere Objekte innerhalb der Datenbank vorgehalten. Wie Sie sicherlich aus dem oben genannten schon sehen, beginnen die Namen aller von KMyMoney verwendeten Tabellen mit den Kleinbuchstaben "kmm". Dieser Standard wird gepflegt und nur solche Tabellen, die damit beginnen, werden aktualisiert. Wenn Sie sich bei der Benennung Ihrer eigenen Abfragen, etc. an diese Konvention halten, sind keine Probleme zu erwarten.

Manuelle Erstellung der Datenbank

Anmerkung

Dieser Abschnitt bietet weitere Informationen für erfahrene Datenbank-Benutzer und kann im allgemeinen übersprungen werden.

Anwendungsfälle

Manchmal ist KMyMoney nicht in der Lage, die Datenbank automatisch richtig zu erstellen oder erstellt sie ohne von Benutzer gewünschte Optionen. Das verwendete Datenbanksystem ist zum Beispiel nicht vollständig kompatibel zum SQL-Standard oder es gibt neue Systeme, die in KMyMoney noch nicht umfassend getestet wurden.

Dann sollten Sie versuchen, nur die Datenbank selbst mit der Anweisung CREATE DATABASE zu erzeugen. Wenn die Datenbank existiert, kann KMyMoney möglicherweise die Tabellen usw. mit der normalen vorher beschriebenen Speicherprozedur der Datenbank generieren.

SQL-Befehle für die Erstellung der Datenbank

Gelingt die automatische Erstellung der SQL-Datenbank nicht, dann können die grundlegenden SQL-Befehle zur Anlage der verschiedenen Tabellen, Ansichten und Indizes für das Programm direkt eingegeben werden. Wählen Sie SQL-Datenbank erzeugen aus dem Menü Extras. Dann öffnet sich folgendes Dialogfenster:

Nach Auswahl des Datenbanktyps werden die zugehörigen SQL-Befehle für die Erstellung der Datenbank im Textfeld angezeigt. Diese Befehle können bearbeitet oder mit SQL speichern in eine Textdatei geschrieben werden. Mit den Befehle in der Textdatei kann die Datenbank mit den Verwaltungsfunktionen des Datenbanksystems erzeugt werden.

Nach der Bearbeitung des SQL-Befehle müssen Sie noch die anderen Felder im Dialog ausfüllen. Informationen dazu finden Sie im vorherigen Abschnitt Erstellen einer Datenbank. Dann kann KMyMoney die Datenbank erzeugen. Klicken Sie dazu auf den Knopf Tabellen erzeugen. Für alle Datenbanken außer SQLite müssen Sie entweder eine Anweisung CREATE DATABASE als ersten Befehl einfügen oder diesen Befehl vorher unabhängig von KMyMoney bereits ausgeführt haben.

Warnung

Sie sollten bei der Bearbeitung der Definitionen aller grundlegenden Tabellen und Ansichten, deren Namen mit „kmm“beginnt, sehr vorsichtig sein. Einige Änderungen wie die Vergrößerung der Länge eines Felds für ein ganze Zahl haben nur geringe Auswirkungen. Sie sollten die Reihenfolge aller Felder aber auf keinen Fall verändern, da KMyMoney dann möglicherweise nicht mehr richtig arbeitet oder Ihre Daten zerstört.

Während das Hinzufügen oder Entfernen von Indizes manchmal die Arbeitsgeschwindigkeit verbessert, kann aber auch das Gegenteil eintreten. Es sind Kenntnisse der internen Funktionsweise von KMyMoney nötig, um unter diesen Bedingen die beste Arbeitsgeschwindigkeit zu erreichen.

Verschlüsselung

Eine Verschlüsselung Ihrer Daten in der Datenbank wird derzeit nicht unterstützt.