Relationaler Textsatz

LaTeX-Dokumente mit SQL-Abfragen

01.06.2006
LaTeX erzeugt perfekten Textsatz, hat aber kein Interface für den Zugriff auf Datenbanken. Mit LaTeXDB integrieren Sie SQL-Abfragen in Ihre LaTeX-Dokumente und erstellen auf diese Weise zum Beispiel Serienbriefe.

OpenOffice-Anwender erstellen mit der Textverarbeitung in wenigen Schritten Serienbriefe, und auch in anderen Textprogrammen ist diese Funktion selbstverständlich – doch das Textsatzsystem LaTeX [1] kennt kein solches Feature. Dabei gibt es hübsche LaTeX-Klassen für die private oder geschäftliche Korrespondenz, aber sie dienen stets nur dem Verfassen einzelner Schreiben.

Liegen Adress- oder andere Daten als Tabelle in einer der Datenbanken MySQL und Postgresql vor, hilft das in Python geschriebene Tool LaTeXDB [2] weiter: Es integriert SQL-Abfragen in ganz normale LaTeX-Dokumente und verhilft damit auch LaTeX-Freunden zur Serienbrieffunktion.

Bei LaTeXDB handelt es sich nicht um eine echte Erweiterung von LaTeX, sondern um ein Wrapper-Skript: Es sucht in einer LaTeX-Datei nach Datenbankabfragen, leitet diese an die Datenbank weiter und trägt die Ergebnisse in die LaTeX-Datei ein.

Einfache Syntax

Der Aufbau eines LaTeX-Dokuments mit SQL-Aufrufen wird am schnellsten anhand des kleinen Beispiels in Listing 1 deutlich. Bei den fett gedruckten Bereichen des Listings handelt es sich um LaTeXDB-Befehle:

  • \texdbconnection definiert eine Verbindung mit der SQL-Datenbank. Das erste Argument gibt den Datenbanktyp an (MySQL oder PostgreSQL), danach folgen Server, Benutzername, Passwort und Name der Datenbank.
  • In \texdbdef tragen Sie eine SQL-Abfrage ein (in der üblichen SQL-Syntax, also select Spalten from Tabelle) und geben Metavariablen (hier: ##Vorname und ##Nachname) an, die später im LaTeX-Code den Zugriff auf die Werte ermöglichen.
  • Am wichtigsten ist schließlich die For-Schleife, die durch das neue Schlüsselwort \texdbfor eingeleitet wird: Für alle Ergebnisse der SQL-Abfrage ("result set") fügt LaTeXDB das zweite Argument in das LaTeX-Dokument ein. Dabei ersetzt es die Metavariablen durch die aktuellen Werte aus der Datenbankabfrage.

Der Beispiel-LaTeX-Code holt aus einer simplen User-Tabelle Vor- und Nachnamen. Für jeden Treffer erzeugt LaTeXDB dann einen Block, der mit dem Briefkopf beginnt, dann den Adressaten persönlich anspricht und nach dem Brief-Footer einen Seitenvorschub auslöst: So entsteht ein einfacher Serienbrief.

Listing 1

\documentclass{…}\texdbconnection{MySQL,localhost,user,passwort,texdb}\texdbdef{##Users}{select Vorname,Nachname from Users}{##Vorname,##Nachname}
\begin{document}\texdbfor{##Users}{
   \briefheader
   Hallo, ##Vorname ##Nachname, \\
   anbei schicken wir Ihnen eine aktuelle Preisliste.
   \brieffooter
   \newpage}
\end{document}

TIPP

Beachten Sie bei eigenen LaTeXDB-Experimenten, dass die Metavariablen (die mit ## beginnen), "präfixfrei" sein müssen – es darf also kein Variablenname das Anfangsstück eines anderen Variablennamen sein: ##vorn und ##vorname dürfen nicht gleichzeitig in einem LaTeXDB-Dokument auftauchen.

Programminstallation

LaTeXDB lässt sich schnell installieren: Nach dem Auspacken des Archivs latexdb-0.3.tar.gz liegt im neu erstellten Verzeichnis eine ausführbare Datei install, die Sie mit Root-Rechten aufrufen – das Skript kopiert ein paar Programmdateien und die Manpage in die /usr/local-Hierarchie. Danach können Sie das Programm direkt starten:

$ latexdb -v
/usr/local/bin/latexdb version 0.3 (2006/04/24).
Relased under the GPL.

Klappt das nicht, ist vielleicht der Pfad falsch eingestellt – /usr/local/bin muss in der Variable $PATH auftauchen.

LinuxCommunity kaufen

Einzelne Ausgabe
 
Abonnements
 

Ähnliche Artikel

  • LaTeX mit Daten aus externen Quellen anreichern
    Ob Serienbrief oder Teilnehmerliste – mit dem richtigen Adapter befüllen Sie LaTeX-Dokumente problemlos mit den Feldinhalten einer Datenbank und erstellen so Druckerzeugnisse in perfekter Qualität.
  • Auf der Heft-CD finden Sie immer Tools und Programm, die zu den Artikeln im Heft passen, sodass Sie gleich ausprobieren können, was Sie im Artikel lesen. Der Datenträger selber bootet in dieser Ausgabe ein Live-System, dass Ihnen in vielen Situationen gut Dienste leistet.
Kommentare

Infos zur Publikation

title_2014_10

Digitale Ausgabe: Preis € 4,95
(inkl. 19% MwSt.)

Mit der Zeitschrift LinuxUser sind Sie als Power-User, Shell-Guru oder Administrator im kleinen Unternehmen monatlich auf dem aktuelle Stand in Sachen Linux und Open Source.

Sie sind sich nicht sicher, ob die Themen Ihnen liegen? Im Probeabo erhalten Sie drei Ausgaben zum reduzierten Preis. Einzelhefte, Abonnements sowie digitale Ausgaben erwerben Sie ganz einfach in unserem Online-Shop.

NEU: DIGITALE AUSGABEN FÜR TABLET & SMARTPHONE

HINWEIS ZU PAYPAL: Die Zahlung ist auch ohne eigenes Paypal-Konto ganz einfach per Kreditkarte oder Lastschrift möglich!       

Tipp der Woche

Schnell Multi-Boot-Medien mit MultiCD erstellen
Schnell Multi-Boot-Medien mit MultiCD erstellen
Tim Schürmann, 24.06.2014 12:40, 0 Kommentare

Wer mehrere nützliche Live-Systeme auf eine DVD brennen möchte, kommt mit den Startmedienerstellern der Distributionen nicht besonders weit: Diese ...

Aktuelle Fragen

Windows 8 startet nur mit externer Festplatte
Anne La, 10.09.2014 17:25, 4 Antworten
Hallo Leute, also, ich bin auf folgendes Problem gestoßen: Ich habe Ubuntu 14.04 auf meiner...
Videoüberwachung mit Zoneminder
Heinz Becker, 10.08.2014 17:57, 0 Antworten
Hallo, ich habe den ZONEMINDER erfolgreich installiert. Das Bild erscheint jedoch nicht,...
internes Wlan und USB-Wlan-Srick
Gerhard Blobner, 04.08.2014 15:20, 2 Antworten
Hallo Linux-Forum: ich bin ein neuer Linux-User (ca. 25 Jahre Windows) und bin von WIN 8 auf Mint...
Server antwortet mit falschem Namen
oin notna, 21.07.2014 19:13, 1 Antworten
Hallo liebe Community, Ich habe mit Apache einen Server aufgesetzt. Soweit, so gut. Im Heimnet...
o2 surfstick software für ubuntu?
daniel soltek, 15.07.2014 18:27, 1 Antworten
hallo zusammen, habe mir einen o2 surfstick huawei bestellt und gerade festgestellt, das der nic...