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 jedoch 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:
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.
Keycloak, OTP, FIDO
11.06.2021
Ich berichtete neulich über die Installation und erste Tests von Keycloak. Nun bin ich tiefer eingetaucht und habe die diversen Möglichkeiten untersucht, die Authentifizierung mittels zweiten Faktors sicherer zu machen.
WeiterlesenAI und ML Android Basteln C und C++ Chaos Datenbanken Docker dWb+ ESP Wifi Garten Geo Go GUI Hardware Java Jupyter JupyterBinder Komponenten Links Linux Markdown Markup Music Numerik OpenSource PKI-X.509-CA Präsentationen Python QBrowser Rants Raspi Revisited Security Software-Test sQLshell TeleGrafana Verschiedenes Video Virtualisierung Windows Upcoming...
In meinem letzten Artikel zum Thema dWb+ beschrieb ich ein neues Feature der Lösung - nunmehr wende ich mich einer wichtigen nichtfunktionalen Anforderung zu
WeiterlesenEin weiteres Self-Hosting-Experiment hat zu zwei neuen Diensten in meinem Docker-Zoo geführt...
WeiterlesenNach meinen Erfolgen mit einem TPM in der Version 1.2 zur Absicherung von SSH-Verbindungen wollte ich versuchen, seine Funktionalität in Java-Anwendungen zu integrieren...
WeiterlesenManche 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.