sQLshell Version 7.9pre2 build 11262

vorhergehende Artikel in: Java Komponenten sQLshell GUI
19.04.2026

Eine neue Version der sQLshell ist verfügbar!

Dieses Release hatte vor allem einen Schwerpunkt: Die sQLshell bietet nicht nur Unterstützung zur Arbeit mit realen Datenbankmanagementsystemen wie etwa PostgreSQL oder H2, sondern stellt auch Möglichkeiten zur Verfügung, mit Systemen zu arbeiten, die Daten zwar in tabellarischer Vorm zur Verfügung stellen, nicht jedochg Datenbanken im klassischen Sinne sind.

Ein solches Pseudo-Datenbankmanagentsystem ist die Funktionalität, die es erlaubt, mit CSV-Dateien in der sQLshell so zu arbeiten, als ob sie Daten in einem relationen Datenbankmanagementsystem wären. Bisher beschränkte sich die Unterstützung dafür lediglich auf SELECT* Anweisungen, die den gesamten Inhalt einer Datei in einem ContentView verfügbar machten.

Diese Funktionalität wurde vor einiger Zeit dahingehend aufgewertet, dass die sQLshell nun versucht, den korrekten Datentyp für die einzelnen Spalten zu erkennen - so wie es etwa in einer bekannten Microsoft-Tabellenkalkulation ebenfalls geschieht. Bis dahin musste man diese Typdefinitionen noch immer in den Kopf der jeweiligen Datei schreiben.

Durch diese Unterstützung von Datentypen war der Grundstein für die neueste Erweiterung gelegt: Daten können jetzt mit SQL-Abfragen extrahiert werden, die Filter durch die WHERE-Klausel unterstützen.

Die Abfragesyntax folgt dem jeweils benutzten Datenbankmanaegmentsystem und der dafür jeweils dokumentierten Syntax. Eine Ausnahme stellt hier das Pseudo-Datenbankmanagementsystem für CSV-Dateien dar: Um solche Dateien mit der sQLshell bearbeiten zu können, wurde ein spezieller JDBC-Treiber erstellt, der Teil der Distribution der sQLshell ist. Dieser Treiber beinhaltet unter anderem eine SQL-Query-Engine, die es erlaubt, einfache SQL-Abfragen zu stellen. Bislang wird lediglich das Filtern der Ergebnisse per WHERE-Klausel unterstützt. Dabei ist es so, dass die sQLshell literale Datentypen bei der Formulierung von WHERE-Klauseln versteht. Folgende Datentypen werden unterstützt:

  • Strings
  • numerische Werte
  • Daten
  • Uhrzeit
  • Zeitstempel
Einige Beispiele für gültige Abfragen sind im Folgenden dargestellt:

SELECT * FROM Table_1 WHERE COLUMN_2 = 'some text';
SELECT * FROM Table_1 WHERE COLUMN_0 >= 0.5;
SELECT * FROM Table_1 WHERE COLUMN_3 BETWEEN '31.01.2000 06:37:11' AND '20.12.2002 13:04:00';
SELECT * FROM Table_1 WHERE COLUMN_3 BETWEEN '06:37:11' AND '13:04:00';
SELECT * FROM Table_1 WHERE COLUMN_3 BETWEEN '31.01.2000' AND '20.12.2002';

Man beachte, dass die Literale für Daten, Zeiten und Zeitstempel immer in Hochkommata eingeschlossen sein müssen. Folgende Formate sind möglich: Für Daten können die Formate dd.MM.yyyy und yyyy-MM-dd benutzt werden, für die Uhrzeit das Format HH:mm:ss und für Zeitstempel dd.MM.yyyy HH:mm:ss und yyyy-MM-dd'T'HH:mm:ss - diese Literale werden von allen Operatoren unterstützt, die Vergleiche durchführen.

Alle Artikel rss Wochenübersicht Monatsübersicht Codeberg Repositories Mastodon Über mich home xmpp


Vor 5 Jahren hier im Blog

  • Entgoogle das Internet!

    18.04.2021

    Ich habe eine weitere interessante Ressource als Ausgangspunkt für ein offeneres, unabhängigeres und freieres Internet ohne Datenkraken gefunden

    Weiterlesen

Neueste Artikel

  • Asymmetrische Kryptographie

    Ich habe mich mit der Idee schon länger getragen: Nochmal einen Rundumschlag zu asymmetrischer Kryptographie zu machen. Dabei werde ich mich auf Demonstrationen der einzelnen Konzepte und Operationen mit Beispielcode konzentrieren und zu jedem der vorgestellten Konzepte mehr oder weniger ausführlich bezüglich der Einsatzszenarien und Vor- und Nachteile Stellung beziehen

    Weiterlesen
  • Handgemachte Musik und die Schwierigkeiten

    Ich muss mal wieder ein wenig Dampf ablassen - und ja - es geht schon wieder um ein Thema, bei dem viele sagen werden "Alter weißer Mann erzählt, wie früher alles besser war"

    Weiterlesen
  • Nochmal zu den Themen x509 und Zertifikate

    Eine Diskussion im $dayjob hat mich darauf aufmerksam gemacht, dass meine Präsentation zum Thema digitale und analoge Identitäten noch nicht alle Aspekte klar genug erläutert.

    Weiterlesen

Manche nennen es Blog, manche Web-Seite - ich schreibe hier hin und wieder über meine Erlebnisse, Rückschläge und Erleuchtungen bei meinen Hobbies.

Wer daran teilhaben und eventuell sogar davon profitieren möchte, muss damit leben, daß ich hin und wieder kleine Ausflüge in Bereiche mache, die nichts mit IT, Administration oder Softwareentwicklung zu tun haben.

Ich wünsche allen Lesern viel Spaß und hin und wieder einen kleinen AHA!-Effekt...

PS: Meine öffentlichen Codeberg-Repositories findet man hier.