Transbase
Transbase ist ein relationales Datenbankmanagementsystem des Unternehmens Transaction Software GmbH. Seine Entwicklung begann in den 1980er-Jahren am Lehrstuhl des Datenbankpioniers Rudolf Bayer unter dem Namen „Merkur“.[1]
Transbase | |
---|---|
Basisdaten
| |
Entwickler | Transaction Software GmbH |
Aktuelle Version | Transbase 8.3 |
Betriebssystem | Unix-Derivate, Linux, Windows, Mac OS, iOS, Raspberry Pi OS, Embedded Linux, Android |
Programmiersprache | C, Java, .Net-Framework, ODBC, PHP, Node.js, Python, Swift |
Kategorie | Datenbankmanagementsystem, Server |
Lizenz | proprietär, Evaluationslizenz frei |
deutschsprachig | nein |
www.transaction.de |
Transbase ist weitgehend konform mit dem SQL-Standard „SQL2 intermediate level“ (SQL-92) und unterstützt diverse Sprachkonstrukte der SQL2-Nachfolger-Versionen (SQL:1999, SQL:2003 etc.).[2]
Geschichte
BearbeitenIn den 1980er-Jahren entwickelte Rudolf Bayer an der TU München gemeinsam mit vielen Doktoranden und Diplomanden das Datenbankmanagementsystem „Merkur“. 1987 gründeten Rudolf Bayer sowie einige Mitarbeiter seines Lehrstuhls die Firma Transaction Software GmbH, die „Merkur“ seitdem weiterentwickelt und kommerziell vertreibt. 1989 wurde „Merkur“ in „Transbase“ umbenannt.
Durch die breite Verwendung von Transbase in der Automobilbranche, speziell für die Erstellung von Ersatzteilverwaltungs und -Dokumentationssystemen, erfolgte sehr früh eine Portierung auf eine größere Zahl von Plattformen (verschiedenste UNIX-Derivate, Linux, Windows, VMS, Mac OS).
Die wesentlichen Entwicklungsschritte von Transbase waren die Integration von Funktionen für verteilte Anfragen auf mehreren Datenbanken, die Erweiterung um ein Volltext-Suchsystem insbesondere auch für Sprachen wie japanisch und chinesisch („Myriad“[3]), die Unterstützung von Data Warehouse Funktionen („Transbase Hypercube“[4]) sowie die dynamische Parallelverarbeitung von Anfragen.[5]
Mit der Version 8 wurde Transbase auf Single-Server-Architektur umgestellt. Als Variante gibt es serverlose „private Datenbanken“, die in die Applikation integriert werden können und insbesondere für den Betrieb auf mobilen Geräten entwickelt wurden.
Mit der Version 8.3 gibt es die Erweiterung Transbase Crowd (s. u.) sowie In-Memory Tabellen, weitere statistische Funktionen, die Konfiguration des Logverhaltens sowie eine Import/Export-Schnittstelle für JSON.
Eigenschaften
BearbeitenStandard-SQL-Eigenschaften
BearbeitenTransbase unterstützt alle wesentlichen vom SQL-Standard geforderten Eigenschaften:[2]
- Umfassendes Transaktionskonzept
- Komplexe Abfragen mit geschachtelten Unterabfragen
- Referenzielle Integrität (u. a. Primärschlüssel, Fremdschlüssel, Check-Constraints)
- Mengenoperationen
- Updatable Views
- Trigger
- Schnittstellen zu C, C++, Java/JDBC, PHP sowie zu ODBC
- Export und Import sowohl von Daten als auch von Datenbankstrukturen (Schemata)
- Integrierte Programmiersprache auf Basis von PSM (Persistent Stored Modules) ab Version 8.4
Erweiterungen
BearbeitenROM-Betrieb
BearbeitenTransbaseCD kann auf Read-Only-Medien wie CD, DVD, Blu-ray direkt oder mit einem so genannten Disk Cache betrieben werden. Der Disk Cache ist persistent und dient sowohl zur Performanzsteigerung (da eine Festplatte schneller als ein Festwertspeicher ist) als auch zur Speicherung von Änderungen. TransbaseCD-Seiten können optional komprimiert werden, wodurch sich in der Regel ein Faktor 2 an Speicherplatz-Ersparnis und meist auch an Verarbeitungsgeschwindigkeit ergibt.
Hypercube-Suche
BearbeitenTransbase Hypercube unterstützt die Analysemethode Relational Online Analytical Processing (ROLAP), welche insbesondere bei der Realisierung von Data-Warehouse-Lösungen eingesetzt wird. Die Suche innerhalb der dabei eingesetzten OLAP-Würfel (engl. hypercubes) wird durch Indexierung mittels UB-Bäumen sehr stark beschleunigt (im Vergleich zu Suchanfragen, bei denen nur klassische Sekundärindexe zum Einsatz kommen).
Verschlüsselung
BearbeitenTransbase verschlüsselt optional alle Seiten, die auf Festplatte gespeichert werden, gemäß dem Advanced Encryption Standard. Im Hauptspeicher liegen sie aus Performanzgründen unverschlüsselt.
Parallelisierung
BearbeitenTransbase bietet parallele Anfrageverarbeitung mittels dynamischer Multithreading-Technologie. Dabei werden entweder einzelne Baumteile des Operatorbaums durch eigene Threads verarbeitet oder Baumpfade mehrfach durch je eigene Threads instantiiert.
Replikation
BearbeitenTransbase unterstützt die Replikation einer Master-Datenbank auf mehrere Slave-Datenbanken. Die Replikation kann synchron (z. B. für hot standby) oder asynchron zur breiten Verteilung auf sehr viele Empfänger erfolgen (auch kaskadiert).
Transbase Crowd
BearbeitenTransbase Crowd wurde konzipiert, um IoT Daten lokal in den Geräten zu speichern und trotzdem zentral abzufragen. Dabei stehen die Nutzung der lokalen Ressourcen sowie die Minimierung des Datentransfers im Vordergrund.
Einschränkungen
BearbeitenDie hier beschriebenen Einschränkungen betreffen die Version 6.9:
- Die Datenbankgröße ist auf 2^31 Seiten oder 128 Tbyte beschränkt.
- Die Seitengröße kann zwischen 4 kByte und 64 kByte gewählt werden.
- Die Tabellengröße wird nur durch die maximale Datenbankgröße limitiert.
- Die maximale BLOB/CLOB-Größe beträgt 2 GByte.
- Die Spaltenzahl einer Tabelle ist auf 256 beschränkt. Zusätzlich muss ein Tupel in eine Seite passen.
- Die Anzahl der Zeilen pro Tabelle ist nicht bzw. nur durch die Größe der Datenbank limitiert.
Einzelnachweise
Bearbeiten- ↑ Geschichte. In: transaction.de. Abgerufen am 7. Februar 2023.
- ↑ a b Transbase® V8.4 documentation. In: transaction.de. Abgerufen am 7. Februar 2023 (englisch).
- ↑ Rudolf Bayer: OMNIS/Myriad: Elektronische Verwaltung und Publikation von multimedialen Dokumenten. In: GI Jahrestagung. 1993, ISBN 3-540-57192-2, S. 482–487.
- ↑ Volker Markl, Frank Ramsak, Roland Pieringer, Robert Fenk, Klaus Elhardt, Rudolf Bayer: The Transbase Hypercube RDBMS: Multidimensional Indexing of Relational Tables. In: ICDE Demo Sessions. 2001, S. 4–6.
- ↑ Ralph Acker, Christian Roth, Rudolf Bayer: Parallel Query Processing in Databases on Multicore Architectures. In: Lecture Notes in Computer Science. Band 5022, 2008, ISBN 978-3-540-69500-4, S. 2–13 (Elektronische Version auf link.springer.com).