Datenbank-spezifische Erweiterungen für sQLshell

vorhergehende Artikel in: sQLshell
28.08.2016

Nachdem die Entwicklung der sQLshell jetzt langsam wieder Fahrt aufnimmt, wurde entschieden, der sQLshell auch Datenbank-spezifische Erweiterungen zu gönnen.

sQLshell Plugins Logo Bisher war die sQLshell ein Werkzeug zur Arbeit mit SQL-Datenbanken. Jegliche Spezifische Erweiterung, die nur für eine Datenbank oder nur einen Hersteller zutraf, wurde konsequent ignoriert. Damit war gewährleistet, dass man sich mit der sQLshell immer und überall zu Hause fühlen konnte. Besonders in Projekten mit Migrationsaufgaben kam das dem Anwender zugute: Er wusste, das alles, was er in der Quelldatenbank mit der sQLshell tun konnte, auch in der Zieldatenbank möglich sein würde.

In letzter Zeit kamen verschiedene neue Features hinzu, die die sQLshell in Bezug auf Hersteller- oder Datenbank-spezifische Features flexibler und anpassbarer machten: Zum einen ist da die Möglichkeit, beim Erzeugen von Tabellen oder beim Hinzufügen neuer Spalten auch Datentypen zu benutzen, die im normalen SQL-Standard bzw. in dem Subset, das die sQLshell über JDBC unterstützt, nicht vorkommen. Zum anderen können jetzt an beliebigen Stellen in SQL-Statements, die über den Editor abgesetzt werden, BeanShell-Skripte ausgewertet werden, deren Ergebnisse dann in das SQL-Skript eingefügt werden.

Ganz neu ist die entstehende Möglichkeit, die sQLshell zu erweitern, indem man für die einzelne Datenbank Implementierungen bestimmter Komponenten oder Aktionen implementiert. Die erste solche Implementierung - und damit das Proof-of-Concept - ist für die Unterstützung des Datentyps Large Object im Datenbank PostgreSQL implementiert worden: OID-Spalten in Postgres werden in der sQLshell als Spalten vom Typ BigInteger gehandhabt (eingeschränkter Umfang unterstützter Typen - daher diese Abbildung). Ist die Datenbank, mit der gearbeitet wird, PostgreSQL, so steht im Kontextmenü auf Tabellenzellen in Spalten vom Typ BigInteger zusätzlich eine Action zur Verfügung, mit der man die darüber referenzierten Large Objects inspizieren kann. Dazu kommt genau die Komponente zum Einsatz, die auch für normale BLOB-Datentypen benutzt wird. Es ist also möglich, sich Bitmap- und SVG-Graphiken, Texte oder PDFs innerhalb der sQLshell anzusehen, ohne sie exportieren zu müssen.

Artikel, die hierher verlinken

COPY <Tabelle> FROM in der sQLshell verfügbar

13.08.2022

Wie bereits in einem früheren Artikel erläutert, wurde die sQLshell um Möglichkeiten ergänzt, Datenbank-spezifische Funktionalitäten anzubieten, die über die im JDBC-Standard definierten hinausgehen.

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


Vor 5 Jahren hier im Blog

  • Derangement - theoretische Betrachtungen

    23.12.2020

    Ich habe bereits über meine Implementierung eines Derangement berichtet - hier noch einige theoretische Nachbetrachtungen...

    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
  • Eingereichter Vortag zum 39C3 - Gentlemen - check your architecture!

    Dieser Vortrag wurde zum 39C3 eingereicht und abgelehnt. Ich möchte einige Open-Source-Frameworks für verschiedene Programmiersprachen vorstellen, mit denen sich Architekturregeln pro Projekt oder Organisation festlegen und mithilfe gängiger Testinfrastrukturen durchsetzen lassen.

    Weiterlesen
  • Chatkontrolle vermeiden ist gleichzeitig unwichtig und nicht genug!

    Das ist ein Abstract eines Vortrages, den ich auf dem 39C3 halten wurde, der aber abgelehnt wurde

    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.